Skip to content

Marhav/Algorithms_and_Data_Structures_Exam

Repository files navigation

Mappeeksamen i Algoritmer og Datastrukturer Høst 2020

Krav til innlevering

Se oblig-tekst for alle krav, og husk spesielt på følgende:

  • Git er brukt til å dokumentere arbeid (minst 2 commits per oppgave, beskrivende commit-meldinger)
  • git bundle er levert inn
  • Hovedklassen ligger i denne path'en i git: src/no/oslomet/cs/algdat/Eksamen/EksamenSBinTre.java
  • Ingen debug-utskrifter
  • Alle testene i test-programmet kjører og gir null feil (også spesialtilfeller)
  • Readme-filen her er fyllt ut som beskrevet

Beskrivelse av oppgaveløsning (4-8 linjer/setninger per oppgave)

Vi har brukt git til å dokumentere arbeidet vårt. Jeg har 23 commits totalt, og hver logg-melding beskriver det jeg har gjort av endringer.

  • Oppgave 1: Forsøkte først å løse denne oppgaven med en node. Ved å forsøke å finne ut når ett av barnepekerene ble null. Dette ble problematisk ifm. while løkken som jeg måtte bruke. Løsningen ble å lage en node som hele tiden husket den forrige noden, slik at jeg kunne jeg referere til foreldrenoden. Har brukt Programkode 5.2 3 a) som referanse.
  • Oppgave 2: Her sjekket jeg først om jeg kunne benytte metoden inneholder(T verdi), det virket ikke som det gikk mtp. at metoden hoppet ut etter ett funn, og det var ikke mulig å sjekke flere noder etter det første funnet. Løsningen ble derfor å kopiere den koden for å modifisere den slik at den løp igjennom hele binærtreet til den kom til null, mens den telte antall matcher. Dette fungerte ikke til å begynne med. Etter ekstensiv feilsøking begynte jeg å mistenke at det kunne være at treet ble bygd feil i oppgave 1 selv om oppgaven bestod testen. Jeg kastet inn håndklet og sjekket Programkode 5.2.3 a) i kompendiet. Riktig nok, jeg hadde glemt å knytte den nye noden jeg opprettet til sin respektive node, men alike vell hadde oppgaven bestått testen. Etter at jeg ordnet dette ble alt grønt uten at jeg trengte å endre noe mer i oppgave 2.
  • Oppgave 3: Det var litt vansklig å umiddelbart få grep om akkurat hva man skulle i denne oppgaven. Men det falt på plass etterhvert og det store problemet ble fort å få koden til å fungere. Løsningen ble å tegne opp treet som testen laget og gå debuggeren nøye etter i sømmene for å sjekke at treet virkelig var korrekt laget og sammtidig finne ut hva koden feilet med. Litt frem og tilbake, så ble testen grønn.
  • Oppgave 4: Etter arbeidet med oppgave 3 og forelesningen 20.10.20, så gikk denne oppgaven lekende lett. Skrev ned kode og committet for hver metode. Bestod testen ved første kompilering.
  • Oppgave 5: Denne oppgaven klønet jeg mye med. Serialize() gikk relativt greit, noe små buggs som jeg fikset fort med ved hjelp av debugger. Deserialize() derimot satt jeg lenge med, før jeg kom på at jeg bare kunne putte leggInn() i en løkke.
  • Oppgave 6: For metoden fjern(T) kopierte jeg koden fra kompendiet, satt meg inn i den, forstod den og la inn støtte for foreldre peker i linje 133 og 134. Metoden fjernAlle(T) løste jeg enkelt ved å kalle metoden fjern(T) i en forløkke som gikk til i var større enn antall(); For nullstill ble det litt mer krøll da den første koden jeg skrev gjorde at koden min andre steder kastet nullpointers bla. når rot ble null. Løsningen ble å kalle fjern(T) metoden i steden får å gjøre det manuelt i metoden. Etter dette fant jeg ut at jeg måtte legge til et spesialtilfelle for å sette foreldrepeker til null. Dette er koden som ligger i linje 134.

About

Algorithms and Data Structures, Exam, 3. Semester

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages