2015-03-19 kl 08-12

Försättsblad till skriftlig
tentamen vid Linköpings
Universitet
Datum för tentamen
Sal
Tid
Kurskod
Provkod
Kursnamn/benämning
Institution
Antal uppgifter som ingår i
tentamen
Antal sidor på tentamen (inkl.
försättsbladet)
Jour/kursansvarig
Telefon under skrivtid
Besöker salen ca kl.
Kursadministratör
(namn, telefon, mailadress)
Tillåtna hjälpmedel
Övrigt
2015-03-19
Samling i korridoren vid SU17/18
08:00 – 12:00
TDDC30
DAT1
Programmering i Java, datastrukturer
och algoritmer
IDA
6 (4 teoretiska och 2 praktiska)
8
Jonas Lindgren
013-281403
Åsa Kärrman,
013-285760,
asa.karrman@liu.se
Inga
Information och frågor hanteras
genom “Tentaklienten”.
Preliminära poänggränser:
3: 20
4: 28
5: 36
Tentamen TDDC30
2015-03-19 kl 08
2 (8)
Teoretisk del
Anvisningar:
Uppgifterna i denna del ska lösas med penna och papper på lösa blad. Vid
tentamens slut lämnas svaren till denna del in till tentamensvakterna.
Alla svar skrivs på lösa blad, där varje deluppgift tydligt markeras. Endast en sida
av bladet används. Varje blad markeras högst upp med personnummer och
sidnummer.
Viktigt: Starta en tentaklient genom att högerklicka på skrivbordet, för att kunna
ta del av allmän information och kunna ställa frågor.
1. (6p) "Snabba frågor"
Alla svar motiveras väl.
a)
b)
c)
d)
e)
f)
Varför väljer man ofta synligheten private hellre än public för medlemsvariabler i en klass?
(1p)
Vad är syftet med undantag/exceptions? (1p)
Vad innebär det att en metod är abstract? (1p)
I “Animal myAnimal = new Animal()” sker två separata saker. Vad innebär “Animal
myAnimal” och vad innebär “new Animal()”? (1p)
Vad innebär det att abstrahera i ett programmeringsperspektiv? (1p)
Varför kan man inte anse att en viss sorteringsalgoritm är 'bäst'? (1p)
2. (6p) "Datastrukturer"
a)
Värdena 2 8 9 4 6 1 3 5 7 ligger i en fullständig maxheap. Rita upp hur heapen ser ut och hur
värdena ligger i den. (2p)
b)
Organisera om siffrorna i trädet nedan så att trädet utgör ett binärt sökträd. (2p)
(”Organisera om siffrorna” innebär att pilarna och noderna förblir på samma plats, endast
siffrorna får byta plats i bilden.)
9
5
2
5
7
4
6
c)
1
3
5
8
Ange i vilken ordning noderna i trädet från b) besöks av en preorder-, postorder-, levelorderoch inorder-traversering. (2p)
Tentamen TDDC30
2015-03-19 kl 08
3 (8)
3. (6p) "Tidskomplexitet"
a)
Rangordna tillväxten, från långsammast tillväxt(bäst) till snabbast tillväxt(sämst), hos
tidskomplexiteterna O(1), O(n⁵), O(nlog(n)), O(5n), O(8n²), O(n), O(2). (2p)
b)
Ange tidskomplexiteten i värsta fallet, med avseende på n, för följande metoder. (n är alltid
ett positivt heltal.) (2p)
int zap(int n) {
return n*n;
}
int count(int n) {
int sum = 0;
if (n > 5) {
for (int i = 0; i < n;
sum += zap(i);
}
} else {
sum = zap(n);
}
return sum;
}
++i) {
void bip(int n) {
for (int i = 0; i < 5; i = i+1) {
System.out.println(n);
}
}
c)
Förenkla följande tre uttryck för tidskomplexitet: (2p)
1) O(5n² + n + 10) × O(7n)
2) O(25n) × O(25log(n))
3) O(2n) + O(3n)
Tentamen TDDC30
2015-03-19 kl 08
4 (8)
4. (6p) "Algoritmer"
a)
Sortera värdena [ 7 2 1 2 4 6 5 ] med bubblesort. Gör detta genom att byta plats på
värden inom fältet, dvs. in-place. Sorteringen ska leda till stigande ordning, dvs 1, 2, 3, osv.
Ange tydligt i svaret hur hela fältet ser ut innan varje platsbyte, samt vilka index som är på
väg att byta plats, med maximalt ett byte per steg. (2p)
b)
Sortera värdena [ 3 4 9 1 7 8 6 2 5 ] med quicksort. Gör detta genom att byta plats
på värden inom fältet, dvs. in-place. Sorteringen ska leda till stigande ordning, dvs 1, 2, 3,
osv. Ange tydligt i svaret hur hela fältet ser ut innan varje platsbyte, samt vilka index som är
på väg att byta plats, med maximalt ett byte per steg. Välj alltid ”det högraste” värdet inom
intervallet som pivot-element. (2p)
c)
Vad innebär det att en sorteringsalgoritm är stabil? Illustrera med ett exempel på en
sorteringsalgoritm som kan implementeras stabil, och ett på en som inte kan implementeras
stabil, med förklaring om varför dessa kan/inte kan implementeras stabila. (2p)
Tentamen TDDC30
2015-03-19 kl 08
5 (8)
Praktisk del
Anvisningar:
Uppgifterna i denna del ska lösas på dator. När alla uppgifter är lösta ska alla filer
som ska examineras lämnas kvar på kontot. Uppgifterna ska alltså inte skickas in
via tentamenssystemet.
Viktigt: Starta en tentaklient genom att högerklicka på skrivbordet, för att kunna
ta del av allmän information och kunna ställa frågor.
Testprogrammet till varje deluppgift ska fungera utan förändringar när tillhörande
deluppgift är löst, om inget annat anges i uppgiften.
Försök att lösa alla uppgifter så långt som möjligt. Om du inte kan lösa en uppgift,
förenkla uppgiften. Glöm i så fall inte att beskriva förenklingen med en tydlig
kommentar i koden. Poängavdrag ges beroende på förenklingens storlek.
Tänk på läsbarhet och namngivning, och även på variablers och metoders
synlighet. Ni behöver inte skriva javadoc för er kod.
För att importera projekt i Eclipse, File → Import, sedan General → Existing
projects into workspace, sedan Browse, och välj projekt i given_files. Viktigt:
Glöm inte att kryssa i “Copy projects into workspace”!
Skapa ett nytt projekt i Eclipse för varje deluppgift, om inget annat anges i
uppgiften.
Som en bilaga finns även en lista över vanliga unixkommandon.
Tentamen TDDC30
2015-03-19 kl 08
6 (8)
5. (8p) “Att räkna löv”
Anna arbetar med ett binärt sökträd, och har kommit så långt att hon har de flesta metoderna,
bland annat add(..) och size(..). Det finns dock mer att göra och Anna har inte riktigt tid att ta
tag i allt just nu, så hon har lejt in er i ett par timmar.
Värde
En nod från Annas binära träd:
Importera Annas projekt från given_files, och hjälp henne med programmet enligt nedan.
a)
För att kontrollera sin implementation vill Anna lägga till en getLeaves-metod, som helt enkelt
returnerar en lista på alla löv i trädet, i godtycklig ordning men utan dubletter. Hjälp Anna
genom att skriva klart leaves-metoden enligt dess dokumentation i koden. (6p)
(Denna deluppgift kan lösas oberoende från övriga deluppgifter.)
b)
Obs: Har du har bonus på labb 3 och 4 tillgodoräknas du deluppgift 5b och 6b.
Anna vill att hennes färdiga träd följer ett gränssnitt. Hon har redan skrivit gränssnittet i filen
AnnasTreeInterface, men hennes kod använder inte gränssnittet än, och måste nog anpassas
lite för att göra det. Uppdatera Annas träd så att det använder gränssnittet. (2p)
(Denna deluppgift kan lösas oberoende från övriga deluppgifter.)
Tentamen TDDC30
2015-03-19 kl 08
7 (8)
6. (10p) “Den öde ön”
Stefan har blivit inspirerad av alla rika kändisar som på senare tid köpt sig sina egna privata
öar. Det vore allt bra kul att äga sin egen öde ö, nånstans att relaxa på beachen med lite
kokosnötter och sol. Problemet är bara att en öde ö är ganska dyr, 3.2 miljoner för den ö
Stefan har ögonen på, så det vill till att Stefan börjar spara redan nu.
Stefan antar att han kan investera sina besparingar på börsen för 7% avkastning i medel, och
för att förenkla det hela antar han också att han måste skatta 0.27% på det totala beloppet och
kompensera för en inflation på 1%, alla dessa per år. För att kunna experimentera med olika
sparbelopp så börjar Stefan knappa på en liten dator-simulation i Java. Han tänker använda en
dubbellänkad lista för att lagra beloppen han sparar samt den avkastning han får, och köra på
med sin simulation tills han sparat ihop till sin ö!
Importera Stefans projekt från given_files, och hjälp honom med programmet enligt nedan.
a)
Stefan vet ungefär hur strukturen kommer se ut, varje nod kommer ha en referens till
föregående och nästa nod, och om inga sådana finns blir dessa referenser null. Listan kommer
också hålla reda på vilken nod som ligger först och sist. Dock har han inte riktigt hunnit
skriva klart addFirst(...) och addLast(...)-metoderna. Hjälp honom skriva klart dessa så att de
bygger en korrekt dubbellänkad lista. (6p)
(Denna deluppgift kan lösas oberoende från övriga deluppgifter.)
b)
Obs: Har du har bonus på labb 3 och 4 tillgodoräknas du deluppgift 5b och 6b.
Den här koden blir nog bra, fast Stefan inser att det vore bra om han kunde vara lite mer
konsekvent i sin kodstruktur. För att åstadkomma detta så skriver han ihop UML-diagrammen
nedan, som representerar hur han helst skulle vilja att hans dubbellänkade lista samt nod såg
ut. Konvertera Stefans dubbellänkade lista så att den följer UML-diagrammen till punkt och
pricka. (4p)
(Denna deluppgift kan lösas oberoende från övriga deluppgifter.)
DoublyLinkedList
- Node first
- Node last
+ void addFirst(...)
+ void addLast(...)
+ int size()
+ boolean isEmpty()
+ double sum()
Node
- double data
~ Node next
~ Node prev
# Node(...)
+ double getData()
+ Node getNext()
+ Node getPrev()
Tentamen TDDC30
2015-03-19 kl 08
Intressanta terminal-kommandon
eclipse &
mkdir målkatalog
rmdir målkatalog
cd målkatalog
cd
cp källfil målfil
mv källfil målkatalog
ls
cat filnamn
Starta Eclipse
Skapa målkatalog
Ta bort målkatalog
Byt aktuell katalog till målkatalog
Byt aktuell katalog till din hemkatalog
Kopiera fil från källfil till målfil
Flytta källfil till målkatalog
Skriver ut alla filer i aktuell katalog
Skriver ut innehållet i filen filnamn
8 (8)