Föreläsning jan 15 v3, jan 22 v4. GT Chapter 6, GT Chapter 7 Hemuppgifter redovisning v4, v5.

Storlek: px
Starta visningen från sidan:

Download "Föreläsning jan 15 v3, jan 22 v4. GT Chapter 6, GT Chapter 7 Hemuppgifter redovisning v4, v5."

Transkript

1 Föreläsning jan 15 v3, jan 22 v4. GT Chapter 6, GT Chapter 7 Hemuppgifter redovisning v4, v5. Planer för läsperiod 3. I GT kap 7 kommer vi att läsa 285 <= sida < 316. I GT kap 8 kommer vi att läsa 333 <= sida < 362, dvs 8.1, 8.2, 8.3, 8.4 och 8.5. I GT kap 9 kommer vi att läsa 379 <= sida < 393, dvs 9.1. I GT kap 10 kommer vi att läsa 447 <= sida < 486. Dock ej avsnitt <= sida <=479 Dessutom skall vi lära oss I/O (Input/Output) i Java och förhoppningsvis ha en avslutande repetitionsföreläsning. GT kap 11 och GT kap 12 ingår inte i kursen. Det är ingen katastrof om man råkar lära sig något av det överhoppade, det mesta av detta ingår i kommande kurser, främst ADK-kusen (Algoritmer-Datastrukturer-Komplexitet). GT Kapitel 6 analogt med boken. Vi har kvar implementationerna i slutet på kapitlet. Klassdiagram för EulerTour med ärvande klass PrintExpressionTour: EulerTour protected InspectableBinaryTree tree; public Object execute(binarytree T) protected Object eulertour(position p) protected void visitexternal(position p, TraversalResult r) protected void visitleft(position p, TraversalResult r) protected void visitbelow(position p, TraversalResult r) protected void visitright(position p, TraversalResult r) protected TraversalResult initresult() protected Object result(traversalresult r) PrintExpressionTour public Object execute(binarytree T) protected void visitexternal(position p, TraversalResult r) protected void visitleft(position p, TraversalResult r) protected void visitbelow(position p, TraversalResult r) protected void visitright(position p, TraversalResult r) GT Kapitel 7 analogt med boken

2 Hemuppgifter redovisning v4. C = 1, 4, 5 B= 1, 3, 4, 5 A = 1, 2, 4, 5, 6 Inlämning under läsperiod 3 senast måndagar klockan CBA-hemuppgift : (delvis P-6.3 GT page 281) Deluppgift: Komplettera bokens text så att klassen LinkedBinaryTree fungerar (på en egen katalog). Alla behövliga gränsnitt, dvs interface Position och alla interface från och med Inspectable- Container till och med BinaryTree i höger del av figure 6.11 GT sid 248, och bokens text till LinkedBinaryTree och BTNode finns på /info/inda01/gtch6/. Det mesta finns också på nätet, varifrån jag kopierat koden. Jag har dock kompletterat BinaryTreegränssnittet med två metoder (som redan finns implementerade i bokens LinkedBinaryTree) : public interface BinaryTree extends InspectableBinaryTree, PositionalContainer { /** Transform v from an external into an internal node by creating two new external nodes and making them the left and right children of v, respectivley. */ public void expandexternal(position v) ; /** Remove the external node w together with its parent v, replacing v with the sibling of w. */ public void removeaboveexternal(position v); Om man försöker kompilera upptäcker man att metoden positions() innehåller begrepp som är oidentiferade. Skriv om metodens "kropp" så att att metoden vid anrop enbart slänger ett RuntimeException med texten "positions() in class LinkedBinaryTree not implemented yet" Gör på motsvarande sätt med de andra metoderna (iterator-returnerare) som saknas. Om allt fungerar skall man nu kunna köra det givna (av mig skrivna) programmet UsePedigree (studera programmet!) som också finns på katalogen som angetts ovan. Körresultat: Antavla : Rut Bo Adam Eva Siv Per Kersti Utskriften visar Ruts härstammning, (far tv, mor t.h), som finns i detta binär träd, en antavla eller stamtavla (engelska pedigree) som vi också kan rita så här (för en gångs skull ritar vi träd rättvänt!): Adam Eva Per Kersti Bo Siv Rut Ruts mormor är alltså Kersti, Ruts far heter Bo osv.

3 Deluppgift: Komplettera programmet UsePedigree så att man gång på gång kan ge en persons namn och få reda på personens relation med personen i roten. Körexempel : Ge namnet på den person vars relation till Rut du vill veta (Sluta ge vagnretur) : Kersti Kersti är mormor till Rut Ge namnet på den person vars relation till Rut du vill veta (Sluta ge vagnretur) : Bo Bo är far till Rut Ge namnet på den person vars relation till Rut du vill veta (Sluta ge vagnretur) : Pia Pia finns ej i släktträdet Ge namnet på den person vars relation till Rut du vill veta (Sluta ge vagnretur) : Du kan utgå ifrån att varje namn bara finns på max ett ställe i trädet. Programmet använder förstås svenska språkets smarta och rekursiva sätt att benämna anfäder och anmödrar. Det är OK att i större träd än det ovanstående få utskrifter som mormorfarfarmor osv. Om du gör A-uppgift 6 så får du inte lösa denna uppgift med hjälp av Euler-tur-mallen. PS. Problemet löses lämpligen med rekursion. Om du blivit så van att programmera OO-mässigt att du ogillar att skriva klassmetoder kan du gå via en klass, kallad Pedigree t ex. DS. 2. A-hemuppgift : (P-6.2 GT page 281) Implementera gränssittet BinaryTree med en vektor med klassen VectorBinaryTree. Använd java.util.vector. Du ska kunna testköra din implementatiion med UsePedigree från uppgift 1, det enda som ska behöver ändras är BinaryTree pg = new LinkedBinaryTree(); till BinaryTree pg = new VectorBinaryTree(); De iterator-returnerande metoderna i gränssnittet som man kunde implementera med att slänga undantag kan även nu "implementeras" på samma sätt. Tips: Det står ju en del i avsnitt GT Jag är lite osäker på hur svårt ni tycker detta är, man måste nog väl förstå definitionerna i kap 5 och kapitel 6 i GT för att lösa uppgiften. Den som vill tänka helt själv kan ju sluta läsa här. Vi måste ju ha ett Position-begrepp för våra träd-element i vektorn. I avsnitt resoneras om två olika sätt att lösa motsvarande problem för vektorimplementerade sekvenser. Det första sättet som föreslås i första stycket på sid 209 avfärdas dock för sekvenser, eftersom positionerna "inte hänger med" vid t ex insertfirst. I våra träd ändras dock aldrig positioner, de bara tillkommer nya när trädet växer "ytterst" eller försvinner positioner när trädet "ansas" genom att man beskär trädet "ytterst", varför även första sättet är ganska OK såvitt jag förstår. Det är nog också det som avses med meningen "That is, each position object v is simply a "wrapper" for the index p(v) into the vector S." på sid 264. Jag använde det första sättet för mitt vektorbaserade binära träd. Jag skrev en klass VectorPosition som implementerar Position och i någon mån ersätter BTNode i implementeringen med länkning. Genom att förse VectorPosition med lämpliga metoder blev koden för VectorBinaryTree rätt lik den givna koden för LinkedBinaryTree.

4 3. B-hemuppgift : Skriv ut antavlan i UsePedigree med hjälp av en Euler-tur, dvs designmönstret "Templet Method Pattern" istället för med den givna metoden public static void preorder- Print(..). Utskriften skall bli densamma, dvs Antavla : Rut Bo Adam Eva Siv Per Kersti På /info/inda01/gtch6/ finns bokens klass EulerTour (GT sid 260) och hjälpklassen TraversalResult. Man skall alltså skriva en subklass PrintPedigree till EulerTour.Testkörningen sker genom att i UsePedigree instansiera ett PrintPedigree-objekt och sedan anropa execute i detta objekt. Har du gjort A-uppgift 2 så kolla att det fungerar också med VectorBinaryTree. Tips: För att hålla reda på nivån (och därmed hur många blanktecken som skall föregå ett namn) använder jag inte alls TraversalResult utan har istället en instansvariabel i mitt PrintPedigreeobjekt som jag räknar upp eller ned på lämpligt sätt. 4. CBA-hemuppgift : Implementera metoden positions() i LinkedBinaryTree på riktigt, dvs så att den retunerar en PositionIterator istället för att slänga ett undantag som vi gjorde i uppgift 1. Om man gör som boken antyder måste man skriva en metod inorderpositions och en klass ArrayPositionIterator som implementerar PositionIterator. Provkör genom att skriva en komplettering av UsePedigree som använderanvända en PositionIterator för att få få denna utskrift Alla elementen med PositonIterator : Rut Bo Adam Eva Siv Per Kersti Har du gjort A-uppgift 2 så gör även samma sak för VectorBinaryTree. Min lösning blev identisk med lösningen för LinkedBinaryTree. 5. CBA-hemuppgift : Kör UNIX-kommando >du på din startkatalog. Katalogerna och filerna bildar ett träd. Hur traverseras trädet? Finns det anledning att städa bland dina filer?

5 6. A-hemuppgift : Lös andra deluppgiften i uppgift 1, att finna någon persons relation med personen i trädets rot, med hjälp av en Euler-tur, dvs med designmönstret "Templet Method Pattern" Utskriften skall bli densamma, t ex : Ge namnet på den person vars relation till Rut du vill veta (Sluta ge vagnretur) : Kersti Kersti är mormor till Rut På /info/inda01/gtch6/ finns bokens klass EulerTour (GT sid 260) och hjälpklassen TraversalResult. Man skall alltså skriva en subklass till en EulerTour.Testkörningen sker genom att i UsePedigree instansiera ett subklass-objekt och sedan anropa execute i detta objekt. Har du gjort A-uppgift 2 så kolla att det fungerar också med VectorBinaryTree. Tips: Jag lät subklassens execute-metod ha denna signatur för att föra över nyckeln till en instansvariabel i subklass-objektet: public Object execute(binarytree T, String ikey)

6 Hemuppgifter redovisning v5. C = 1, 2 B= 2, 3, 4 A = 2, 3, 4, 5 Inlämning under läsperiod 3 senast måndagar klockan Allmänt om uppgifterna : I boken byggs implementationer av mer avancerade ADT upp med hjälp av implementationer av enklare ADT, man kan alltså tänka sig att en DLPriorityQueue skulle byggas på en List från kapitel 5 och ett HeapTree med BinaryTree från kap 6. Men till slut blir det nog enklare (och mindre kod) att direkt bygga en ADT från "scratch", vilket jag tänkt att vi gör i sorteringsuppgifterna denna vecka. För enkelhets skull är nycklarna och elementen i de "Items", dvs nyckel-element-par, vi skall sortera ofta strängar med samma innehåll. När vi skapar implementationer av prioitetsköer, t ex DLPriorityQueue i uppgift 1 och HeapPriorityQueue i uppgift 4 skall vi som argument till konstruktorn ge ett objekt som implementerar gränsnittetet Comparator. Det finns ett förslag till detta gränssnitt i boken, men också ett annat i java.util. Skillnaderna diskuteras i GT överst på sidan 295, och jag tycker att vi använder java.bibliotekets version. Många klasser i Javabiblioteket, bl a String, implementerar ytterligare ett annat gränssitt Comparable, vilket jag utnyttjat i MyComparator. Jag ger ett MyComparatorobjekt till mina proritetsköer som används på nycklarna vid sorteringarna för att avgöra ordningen mellan "Items": import java.util.*; class MyComparator implements Comparator{ // implements java.util.comparator public int compare(object a, Object b) { if (a instanceof Comparable b instanceof Comparable ) { return ((Comparable) a).compareto((comparable) b); else { throw new RuntimeException("compare() in MyComparator," + " arguments must be Comparable"); Körresultaten i programmen är ofta av denna typ: /*Körresultat :...>java...sort... bertil david adam ludvig martin zero rudolf adam bertil david ludvig martin rudolf zero */

7 1. C-hemuppgift : Implementera en prioritetskö med en dubbellänkad lista (som hålls sorterad) i en klass DLPriority- Queue som skall implementera gränsnittet PriorityQueue. Gränssittet finns givet på /info/inda01/gtch7, tillsammans med DLItemNode, och Item som man också har glädje av. Med hjälp av implementationen kan man göra en insättningssortering med detta program (finns också på info/inda01/gtch7 ), som alltså kan användas som test på att implementationen är riktig: import java.util.*; public class PriorityQueueSort { public static void main(string [] arg) { // PriorityQueue p = new HeapPriorityQueue(new MyComparator()) ; PriorityQueue p = new DLPriorityQueue(new MyComparator()) ; for (int i = 0; i < arg.length; i = i+1) { p.insertitem(arg[i], arg[i]); for (int i = 0; i < arg.length; i = i+1) { System.out.println(p.removeMin()); Tips: Min favoritstruktur är dubbellänkade noder, men till skillnad från boken med samma nod som både header och trailer, dvs vi får en cirkulär dubbellänkad lista med en vaktpost (sentinel) som är både "header" och "trailer". Till vänster en bild på strukturen när den är tom, till höger med tre element: 0 tom prioitetskö 3 prioitetskö med 3 element vaktpost, sentinel vaktpost, sentinel david david adam adam bertil bertil När du skriver insertitem kommer du antagligen att skriva en snurra som söker efter första elementet som har större nyckel, dvs du traskar vidare i kedjan så länge examinerat element har för liten nyckel. Avbrottsvillkoret i snurran kan skrivas enklare om man fyller vaktposten med nyckeln i det element som man skall stoppa in i kedjan.

8 2. CBA-hemuppgift : Implementera en "på-plats"sortering, (In-place-sort). Du kan välja mellan att göra en bubbelsortering eller en insättningsortering genom att kommentera bort de andra sorterarna i nedanstående testprogram. Inget av dessa sorteringssätt är något vidare val för på-plats-sortering, vilket däremot "in-place-heapsort" är, vilket är en senare uppgift. Detta testprogram (på /info/inda01/gtch7) kan används för att kontrollera implementationen: import java.util.*; public class SortInPlace { // finns på/info/inda01/gtch7 public static void main(string [] arg) { Vector v = new Vector(); for (int i = 0; i < arg.length; i = i+1) { v.add(new JustItem(arg[i], arg[i])); //Sorter p = new HeapSort(new MyComparator(), v); //Välj sorterare!!!!! Sorter p = new BubbelSort(new MyComparator(), v); //Sorter p = new InsertionSort(new MyComparator(), v); p.sort(); for (int i = 0; i < v.size(); i = i+1) { System.out.println((String) ((Item) (v.get(i))).element()); public interface Sorter { // Gränssnittet Sorter (på /info/inda01/gtch7) public void sort(); Tips: Det är alltså java.util.vector v som blir sorterad. Uppgiften är att skriva klassen Bubbel sort eller klassen InsertionSort som skall implementera interface Sorter, dvs klassen skall ha metoden sort(). Ett Sorter-objekt får en vektor och en komparator när det skapas. Vektorn kan sedan sorteras med sort(), varvid komparatorn bestämmer vad som menas med "mindre än".

9 3.BA-hemuppgift : Det kan ju vara roligt att se vad som händer under på-plats-sorteringen i uppgift 2. Följande givna program lägger in den sekvens items som skall sorteras dels i en vanlig vektor v, dels i en Final- RankRankVector frrv. Märk att "items" är gemensamma! Därefter sorteras v. Med hjälp av v kan vi nu byta elementen i alla items så att vi i stället har slutgiltiga rangen som elementvärde. Om vi nu sorterar frrv så skrivs hela frrv ut varje gång vi anropar set, pga att set är omdefinerad för FinalRankRankVector. Om du kombinerar SortInPlace1 med den sorterarare du gjort i förgående uppgift skall du kunna provköra för att få frrv utskriven gång på gång. Utskriften består av varje items <rang> <nykel> <slutgiltig rang>. import java.util.*; public class SortInPlace1 { // finns på/info/inda01/gtch7 public static void main(string [] arg) { // Move items to be sorted to v and frrv Vector v = new Vector(); Vector frrv = new FinalRankRankVector(); for (int i = 0; i < arg.length; i = i+1) { Item ii = new JustItem(arg[i], arg[i]); frrv.add(ii); v.add(ii); // Get a sorter for v, and sort //Sorter p = new InsertionSort(new MyComparator(), v); //Välj sorterare!!!!! Sorter p = new BubbelSort(new MyComparator(), v); //Sorter p = new HeapSort(new MyComparator(), v); p.sort(); System.out.println("Result of sort:"); for (int i = 0; i < v.size(); i = i+1) { System.out.println((String) ((Item) (v.get(i))).element()); // Change item elemnets to final rank for (int i = 0; i < v.size(); i = i+1) { ((Item) (v.get(i))).setelement(new Integer(i)); System.out.println("finalrankrankvector :"); for (int i = 0; i < frrv.size(); i = i+1) { System.out.println((Integer) ((Item) (frrv.get(i))).element()); // Sort frrv, which is a // FinalRankRankVector => vector will be shown at every set //p = new InsertionSort(new MyComparator(), frrv);//välj sorterare!!!!! p = new BubbelSort(new MyComparator(), frrv); //p = new InsertionSort(new MyComparator(), frrv); p.sort();

10 import java.util.*; public class FinalRankRankVector extends Vector { // finns på/info/inda01/gtch7 public void show() { for (int i = 0; i < size() ; i = i+1) { Item ii = (Item) get(i); if ( ii!= null) { System.out.print(" " + i + " " + ii.key() + " " + ii.element()); else { System.out.print(" " + i + " "); System.out.println(); public Object set(int index, Object oitem) { //overrides inherited set Object result = super.set(index, oitem); show(); return result; Uppgiften är att komplettera FinalRankRankVector så att man även får se sorteringen i en Java- Frame. Provkör klassfilen /info/inda01/gtch7/sortinplace1 så får du se min bubbelsortering "live in action". T ex... >java SortInPlace1 bertil adam david tore sverker erik eva sven zero per filip Gör teminalfönstret smalt och lägg de vid sedan så att fönstret inte skymmer "framen". Gör terminalfönstret aktivt och ge vagnreturer, så får man ser hur elementen bubblar på tills allt är sorterat, dvs man får en diagonal i fönstret. Ett element skrivs alltså ut på (rang, slutgiltig rang)-stället i ett n x n rutmönster, där n = v.size(); Tips: Jag försåg min FinalRankRankVector med en Frame FinalRankRankFrame (storleken 800 pixel * 800 pixel) som använder GridLayout och har en matris java.label []. Metoden show() i FinalRankRankVectora kompletteras så att den även skriver ny text i "framen".

11 4.BA-hemuppgift : Implementera (direkt, utan att gå via något ADT binärt träd som boken gör) en prioritetskö med en heap (i en java.util.vector) med en klass HeapPriorityQueue som skall implementera gränsnittet PriorityQueue. Gränsittet finns givet på /info/inda01/gtch7, tillsammans med bokens Item, som man ju har glädje av. Programmet kan testköras med samma testprogram som uppgift1, om man skriver i stället för PriorityQueue p = new HeapPriorityQueue(new MyComparator()) ; PriorityQueue p = new DLPriorityQueue(new MyComparator()) ; Märk finessen med "att programmera mot ett interface"!. Programmet gör nu förstås en "heap"- sortering. Delar av texten för uppgift 1 är relevant för denna uppgift också, förutom bokens avsnitt på sid 314.

12 5. A-hemuppgift : Implementera en "på-plats"heap-sortering, (In-place heap-sort). Testprogrammmet i uppgift 2 kan ändras så att man kan testa denna uppgift. Även testprogrammmet i uppgift 3 och din lösning till uppgift 3 skall kunna fungera med lösningen till denna uppgift, dvs du skall kunna se din "på-plats"heapsortering "live". Tips: Man kan säkert skriva HeapSort genom att bygga om HeapPriorityQueue, vilket är OK. Jag har dock löst problemet så här genom arv (mer intellektuell utmaning kanske): PriorityQueue HeapPriorityQueue protected Comparator comp protected Vector v protected int size... public void insertitem(object k, Object e)... /* m fl */ Sorter HeapSort : public HeapSort(Comparator ic, Vector iv) public void sort() private void insertitem(item ii) Vid arv behöver man en "omvänd komparator" vilket man kan få så här: class MyInvertedComparator implements Comparator{ private Comparator c; public MyInvertedComparator(Comparator ic) { c = ic; public int compare(object a, Object b) { return -c.compare(a,b);

Laboration 13, Arrayer och objekt

Laboration 13, Arrayer och objekt Laboration 13, Arrayer och objekt Avsikten med denna laboration är att du ska träna på att använda arrayer. Skapa paketet laboration13 i ditt laborationsprojekt innan du fortsätter med laborationen. Uppgift

Läs mer

TDDC30. Objektorienterad programmering i Java, datastrukturer och algoritmer. Föreläsning 9 Jonas Lindgren, Institutionen för Datavetenskap, LiU

TDDC30. Objektorienterad programmering i Java, datastrukturer och algoritmer. Föreläsning 9 Jonas Lindgren, Institutionen för Datavetenskap, LiU TDDC30 Objektorienterad programmering i Java, datastrukturer och algoritmer. Föreläsning 9 Jonas Lindgren, Institutionen för Datavetenskap, LiU På denna föreläsning: Prioritetskö Heap Representation som

Läs mer

Föreläsning 10 Innehåll. Prioritetsköer och heapar. ADT Prioritetskö. Interface för Prioritetskö. Exempel på vad du ska kunna

Föreläsning 10 Innehåll. Prioritetsköer och heapar. ADT Prioritetskö. Interface för Prioritetskö. Exempel på vad du ska kunna Föreläsning Innehåll Prioritetsköer och heapar Prioritetsköer och heapar ADT prioritetskö Klassen PriorityQueue i java.util Implementering med lista ar Implementering av prioritetskö med heap Sortering

Läs mer

Inga hjälpmedel tillåtna.

Inga hjälpmedel tillåtna. KTH Nada Leif Kusoffsky INDA Introduktion till Datalogi Tentamen 20002 April 05 Observera: Skriv hela tentan. Man kan inte längre tillgodoräkna sig resultat från kontrollskrivningar, ej heller bonuspoäng

Läs mer

Seminarium 13 Innehåll

Seminarium 13 Innehåll Seminarium 13 Innehåll Prioritetsköer och heapar Prioritetsköer ADTn Klassen PriorityQueue i java.util Implementering med lista Heapar ADTn För implementering av prioritetskö För sortering Efter seminariet

Läs mer

Föreläsning 14 Innehåll

Föreläsning 14 Innehåll Föreläsning 14 Innehåll Abstrakta datatyper, datastrukturer Att jämföra objekt övriga moment i kursen Om tentamen Skriftlig tentamen både programmeringsuppgifter och teoriuppgifter Hitta fel i fingerade

Läs mer

Föreläsning 8 - del 2: Objektorienterad programmering - avancerat

Föreläsning 8 - del 2: Objektorienterad programmering - avancerat Föreläsning 8 - del 2: Objektorienterad programmering - avancerat Johan Falkenjack johan.falkenjack@liu.se Linköpings universitet Sweden December 4, 2013 1 Innehåll Arv och andra viktiga begrepp Abstrakta

Läs mer

Laboration 1 - Grunderna för OOP i Java

Laboration 1 - Grunderna för OOP i Java Uppdaterad: 2006-08-31 Laboration 1 - Grunderna för OOP i Java Inledning Laborationen går ut på att lära sig grunderna för objektorienterad programmering, samt motsvarande språkkonstruktioner i Java. Labben

Läs mer

Föreläsning 8: Exempel och problemlösning

Föreläsning 8: Exempel och problemlösning TDA 545: Objektorienterad programmering Föreläsning 8: Exempel och problemlösning Magnus Myréen Chalmers, läsperiod 1, 2015-2016 De tre senaste föreläsningarna Läsanvisning: kap 2 & 13 meddelanden och

Läs mer

Tentamen, Algoritmer och datastrukturer

Tentamen, Algoritmer och datastrukturer UNDS TEKNISKA ÖGSKOA (6) Institutionen för datavetenskap Tentamen, Algoritmer och datastrukturer 23 8 29, 8. 3. Anvisningar: Denna tentamen består av fem uppgifter. Totalt är skrivningen på 36 poäng och

Läs mer

Programmering för Språkteknologer II. Innehåll. Associativa datastrukturer. Associativa datastrukturer. Binär sökning.

Programmering för Språkteknologer II. Innehåll. Associativa datastrukturer. Associativa datastrukturer. Binär sökning. Programmering för Språkteknologer II Markus Saers markus.saers@lingfil.uu.se Rum -040 stp.lingfil.uu.se/~markuss/ht0/pst Innehåll Associativa datastrukturer Hashtabeller Sökträd Implementationsdetaljer

Läs mer

Föreläsning 9 Innehåll

Föreläsning 9 Innehåll Föreläsning 9 Innehåll Träd, speciellt binära träd egenskaper användningsområden implementering Datavetenskap (LTH) Föreläsning 9 HT 2017 1 / 31 Inlämningsuppgiften De föreläsningar som inlämningsuppgiften

Läs mer

Föreläsning 3: Abstrakta datastrukturer, kö, stack, lista

Föreläsning 3: Abstrakta datastrukturer, kö, stack, lista Föreläsning 3: Abstrakta datastrukturer, kö, stack, lista Abstrakt stack Abstrakt kö Länkade listor Abstrakta datatyper Det är ofta praktiskt att beskriva vilka operationer man vill kunna göra på sina

Läs mer

ADT Prioritetskö. Föreläsning 12 Innehåll. Prioritetskö. Interface för Prioritetskö. Prioritetsköer och heapar

ADT Prioritetskö. Föreläsning 12 Innehåll. Prioritetskö. Interface för Prioritetskö. Prioritetsköer och heapar Föreläsning 1 Innehåll Prioritetsköer och heapar Prioritetsköer och heapar ADT prioritetskö Klassen PriorityQueue i java.util Heapar Implementering av prioritetskö med heap Sortering med hjälp av heap

Läs mer

Datastrukturer i kursen. Föreläsning 8 Innehåll. Träd rekursiv definition. Träd

Datastrukturer i kursen. Föreläsning 8 Innehåll. Träd rekursiv definition. Träd Föreläsning 8 Innehåll Datastrukturer i kursen Träd, speciellt binära träd egenskaper användningsområden implementering Undervisningsmoment: föreläsning 8, övningsuppgifter 8, lab 4 Avsnitt i läroboken:

Läs mer

Föreläsning 7. Träd och binära sökträd

Föreläsning 7. Träd och binära sökträd Föreläsning 7 Träd och binära sökträd Föreläsning 7 Träd Binära träd Binärt sökträd som ADT Implementering av binärt sökträd Travestera binärt sökträd Sökning Insättning/borttagning Läsanvisningar och

Läs mer

Kungliga Tekniska Högskolan Ämneskod 2D4134 Nada Tentamensdag 2001 - maj - 19 Tentamen i Objektorientering och Java Skrivtid 5 h

Kungliga Tekniska Högskolan Ämneskod 2D4134 Nada Tentamensdag 2001 - maj - 19 Tentamen i Objektorientering och Java Skrivtid 5 h Kungliga Tekniska Högskolan Ämneskod 2D4134 Nada Tentamensdag 2001 - maj - 19 Tentamen i Objektorientering och Java Skrivtid 5 h Antalet uppgifter : 2 (20p + 20p = 40 p) ) Lärare, jourhavande lärare :

Läs mer

Tentamen Programmeringsteknik II Inledning. Anmälningskod:

Tentamen Programmeringsteknik II Inledning. Anmälningskod: Tentamen Programmeringsteknik II 2016-01-11 Inledning I bilagan finns ett antal mer eller mindre ofullständiga klasser. Några ingår i en hierarki: List, SortedList, SplayList och ListSet enligt vidstående

Läs mer

Föreläsning 2. Länkad lista och iterator

Föreläsning 2. Länkad lista och iterator Föreläsning 2 Länkad lista och iterator Föreläsning 2 Länkad-lista Lista implementerad med en enkellänkad lista Iterator Implementering av en Iterator Dubbellänkad lista och cirkulär lista LinkedList JCF

Läs mer

Anmälningskod: Lägg uppgifterna i ordning. Skriv uppgiftsnummer (gäller B-delen) och din kod överst i högra hörnet på alla papper

Anmälningskod: Lägg uppgifterna i ordning. Skriv uppgiftsnummer (gäller B-delen) och din kod överst i högra hörnet på alla papper Tentamen Programmeringsteknik II 2018-10-19 Skrivtid: 8:00 13:00 Tänk på följande Skriv läsligt. Använd inte rödpenna. Skriv bara på framsidan av varje papper. Lägg uppgifterna i ordning. Skriv uppgiftsnummer

Läs mer

F12 - Collections. ID1004 Objektorienterad programmering Fredrik Kilander

F12 - Collections. ID1004 Objektorienterad programmering Fredrik Kilander F12 - Collections ID1004 Objektorienterad programmering Fredrik Kilander fki@kth.se Collections (samlingar) En collection är ett objekt som fungerar som en samling av andra objekt En collection erbjuder

Läs mer

Tentamen Programmering fortsättningskurs DIT950

Tentamen Programmering fortsättningskurs DIT950 Tentamen Programmering fortsättningskurs Datum: 2015-03-17 Tid: 08.30-12.30 Hjälpmedel: Engelskt-Valfritt språk lexikon Betygsgränser: U: -23 G: 24-43 VG: 44-60 (max 60) Lärare:. Någon besöker ca 10.00

Läs mer

Föreläsning 3 Datastrukturer (DAT037)

Föreläsning 3 Datastrukturer (DAT037) Föreläsning 3 Datastrukturer (DAT037) Fredrik Lindblad 1 2016-11-07 1 Slides skapade av Nils Anders Danielsson har använts som utgångspunkt Se http://wwwcsechalmersse/edu/year/2015/course/dat037 Förra

Läs mer

Dagens program. Programmeringsteknik och Matlab. Objektorienterad programmering. Vad är vitsen med att ha både metoder och data i objekten?

Dagens program. Programmeringsteknik och Matlab. Objektorienterad programmering. Vad är vitsen med att ha både metoder och data i objekten? Programmeringsteknik och Matlab Övning 4 Dagens program Övningsgrupp 2 (Sal Q22/E32) Johannes Hjorth hjorth@nada.kth.se Rum 4538 på plan 5 i D-huset 08-790 69 02 Kurshemsida: http://www.nada.kth.se/kurser/kth/2d1312

Läs mer

ADT Prioritetskö. Föreläsning 13 Innehåll. Prioritetskö vs FIFO-kö. Prioritetskö Exempel på användning. Prioritetsköer och heapar

ADT Prioritetskö. Föreläsning 13 Innehåll. Prioritetskö vs FIFO-kö. Prioritetskö Exempel på användning. Prioritetsköer och heapar Föreläsning 1 Innehåll ADT Prioritetskö Prioritetsköer och heapar Prioritetsköer och heapar ADT prioritetskö Klassen PriorityQueue i java.util ar Implementering av prioritetskö med heap Sortering med hjälp

Läs mer

Det är principer och idéer som är viktiga. Skriv så att du övertygar rättaren om att du har förstått dessa även om detaljer kan vara felaktiga.

Det är principer och idéer som är viktiga. Skriv så att du övertygar rättaren om att du har förstått dessa även om detaljer kan vara felaktiga. Tentamen Programmeringsteknik II 2015-05-26 Skrivtid: 0800 1300 Tänk på följande Skriv läsligt! Använd inte rödpenna! Skriv bara på framsidan av varje papper. Börja alltid ny uppgift på nytt papper. Lägg

Läs mer

Inlämningsuppgiften. Föreläsning 9 Innehåll. Träd. Datastrukturer i kursen

Inlämningsuppgiften. Föreläsning 9 Innehåll. Träd. Datastrukturer i kursen Föreläsning 9 Innehåll Inlämningsuppgiften De föreläsningar som inlämningsuppgiften bygger på är nu klara. Det är alltså dags att börja arbeta med inlämningsuppgiften. Träd, speciellt binära träd egenskaper

Läs mer

Lösningar Datastrukturer TDA

Lösningar Datastrukturer TDA Lösningar Datastrukturer TDA416 2016 12 21 roblem 1. roblem 2. a) Falskt. Urvalssortering gör alltid samma mängd av jobb. b) Sant. Genom att ha en referens till sista och första elementet, kan man nå både

Läs mer

Anmälningskod: Lägg uppgifterna i ordning. Skriv uppgiftsnummer (gäller B-delen) och din kod överst i högra hörnet på alla papper

Anmälningskod: Lägg uppgifterna i ordning. Skriv uppgiftsnummer (gäller B-delen) och din kod överst i högra hörnet på alla papper Tentamen Programmeringsteknik I 2018-03-16 Skrivtid: 8:00 13:00 Tänk på följande Skriv läsligt. Använd inte rödpenna. Skriv bara på framsidan av varje papper. Lägg uppgifterna i ordning. Skriv uppgiftsnummer

Läs mer

Hitta k största bland n element. Föreläsning 13 Innehåll. Histogramproblemet

Hitta k största bland n element. Föreläsning 13 Innehåll. Histogramproblemet Föreläsning 13 Innehåll Algoritm 1: Sortera Exempel på problem där materialet i kursen används Histogramproblemet Schemaläggning Abstrakta datatyper Datastrukturer Att jämföra objekt Om tentamen Skriftlig

Läs mer

DAT043 - Föreläsning 7

DAT043 - Föreläsning 7 DAT043 - Föreläsning 7 Model-View-Controller, mer om klasser och interface (arv, ) 2017-02-06 Designmönstret Observer avläser Observer Observable meddelar Observer avläser En eller flera objekt registrerar

Läs mer

Observera : Lämna in svaren på frågorna på detta blad genom att lämna in detta blad!

Observera : Lämna in svaren på frågorna på detta blad genom att lämna in detta blad! KTH Nada Leif Kusoffsky INDA Introduktion till Datalogi Tentamen 2002 augusti 22 Observera: Skriv hela tentan. Man kan inte längre tillgodoräkna sig resultat från kontrollskrivningar, ej heller bonuspoäng

Läs mer

Föreläsning 3 Datastrukturer (DAT037)

Föreläsning 3 Datastrukturer (DAT037) Föreläsning 3 Datastrukturer (DAT037) Fredrik Lindblad 1 6 november 2017 1 Slides skapade av Nils Anders Danielsson har använts som utgångspunkt Se http://wwwcsechalmersse/edu/year/2015/course/dat037 1

Läs mer

TENTAMEN I PROGRAMMERING. På tentamen ges graderade betyg:. 3:a 24 poäng, 4:a 36 poäng och 5:a 48 poäng

TENTAMEN I PROGRAMMERING. På tentamen ges graderade betyg:. 3:a 24 poäng, 4:a 36 poäng och 5:a 48 poäng TENTAMEN I PROGRAMMERING Ansvarig: Jan Skansholm, tel 7721012 Betygsgränser: Hjälpmedel: Sammanlagt maximalt 60 poäng. På tentamen ges graderade betyg:. 3:a 24 poäng, 4:a 36 poäng och 5:a 48 poäng Skansholm,

Läs mer

public interface Skrivbar { void skriv(); } public class Punkt implements Skrivbar { public double x; public double y;

public interface Skrivbar { void skriv(); } public class Punkt implements Skrivbar { public double x; public double y; public interface Skrivbar { void skriv(); public class Punkt implements Skrivbar { public double x; public double y; public Punkt(double xx, double yy) { x = xx; y = yy; public Punkt() { @Override public

Läs mer

Samlingar Collection classes

Samlingar Collection classes Samlingar Collection classes Sven-Olof Nyström Uppsala Universitet 17 mars 2005 Skansholm: Kapitel 9, 19 Se även Suns tutorial om Collections Olika slag av samlingar i Java Arrayer (Till exempel: int[])

Läs mer

Tentamen i Objektorienterad programmering

Tentamen i Objektorienterad programmering CHALMERS TEKNISKA HÖGSKOLA Datavetenskap TDA547 Tentamen i Objektorienterad programmering Lördagen 12 mars 2011, 8.30 12.30. Jourhavande lärare: Björn von Sydow, tel 0762/981014. Inga hjälpmedel. Lösningar

Läs mer

Försättsblad till skriftlig tentamen vid Linköpings Universitet

Försättsblad till skriftlig tentamen vid Linköpings Universitet Försättsblad till skriftlig tentamen vid Linköpings Universitet Datum för tentamen 2013-03-27 Sal Tid 08:00 12:00 Kurskod Provkod Kursnamn/benämning Institution Antal uppgifter som ingår i tentamen Antal

Läs mer

Tentamen Programmeringsteknik II och NV2 (alla varianter) 2008-12-10. Skriv bara på framsidan av varje papper.

Tentamen Programmeringsteknik II och NV2 (alla varianter) 2008-12-10. Skriv bara på framsidan av varje papper. Tentamen Programmeringsteknik II och NV2 (alla varianter) 2008-12-10 Skrivtid: 0800-1300 Inga hjälpmedel. Tänk på följande Maximal poäng är 40. För betygen 3 krävs 18 poäng. För betygen 4, 5 kommer något

Läs mer

Idag. Exempel, version 2. Exempel, version 3. Ett lite större exempel

Idag. Exempel, version 2. Exempel, version 3. Ett lite större exempel Idag Ett exempel Undantag Substitutierbarhet, subtyper, subklasser När val av metod beror av typerna hos två objekt Lite om överlagring Exempel, version 2 Notera: för samtliga figurer gäller: arean av

Läs mer

Algoritmer. Två gränssnitt

Algoritmer. Två gränssnitt Objektorienterad programmering E Algoritmer Sökning Linjär sökning Binär sökning Tidsuppskattningar Sortering Insättningssortering Föreläsning 9 Vad behöver en programmerare kunna? (Minst) ett programspråk;

Läs mer

LÖSNINGSFÖRSLAG Programmeringsteknik För Ing. - Java, 5p

LÖSNINGSFÖRSLAG Programmeringsteknik För Ing. - Java, 5p UMEÅ UNIVERSITET Datavetenskap 010530 LÖSNINGSFÖRSLAG Programmeringsteknik För Ing. - Java, 5p Betygsgränser 3 21,5-27 4 27,5-33,5 5 34-43 Uppgift 1. (4p) Hitta de fel som finns i nedanstående klass (det

Läs mer

Föreläsning 4 Datastrukturer (DAT037)

Föreläsning 4 Datastrukturer (DAT037) Föreläsning 4 Datastrukturer (DAT037) Fredrik Lindblad 1 2016-11-10 1 Slides skapade av Nils Anders Danielsson har använts som utgångspunkt Se http://wwwcsechalmersse/edu/year/2015/course/dat037 Förra

Läs mer

Grundkurs i programmering, 6 hp (725G61) Dugga 2 tillfälle 2

Grundkurs i programmering, 6 hp (725G61) Dugga 2 tillfälle 2 AID-nummer: Datum: 2014-12-18 Kurskod: 725G61 Provkod: LAB1 Grundkurs i programmering, 6 hp (725G61) Dugga 2 tillfälle 2 Skrivningstid: 2014-12-18 klockan 8.00-10.00. Hjälpmedel: Inga. För varje fråga

Läs mer

Föreläsning 9 Innehåll

Föreläsning 9 Innehåll Föreläsning 9 Innehåll Binära sökträd algoritmer för sökning, insättning och borttagning, implementering effektivitet balanserade binära sökträd, AVL-träd Abstrakta datatyperna mängd (eng. Set) och lexikon

Läs mer

13 Prioritetsköer, heapar

13 Prioritetsköer, heapar Prioritetsköer, heapar 31 13 Prioritetsköer, heapar U 101. En prioritetskö är en samling element där varje element har en prioritet (som används för att jämföra elementen med). Elementen plockas ut i prioritetsordning

Läs mer

Algoritmer och datastrukturer

Algoritmer och datastrukturer Algoritmer och datastrukturer Binära sökträd Hash Tabeller Sökning Många datastukturer försöker uppnå den effektivaste sökningen I arrayer - linjer sökning, och binärt sökning när arrayen kan vara sörterad

Läs mer

TENTAMEN PROGRAMMERINGSMETODIK MOMENT 2 - JAVA, 4P

TENTAMEN PROGRAMMERINGSMETODIK MOMENT 2 - JAVA, 4P UME UNIVERSITET Datavetenskap 981212 TENTAMEN PROGRAMMERINGSMETODIK MOMENT 2 - JAVA, 4P Datum : 981212 Tid : 9-15 HjŠlpmedel : Inga Antal uppgifter : 9 TotalpoŠng : 60 (halva pošngtalet kršvs normalt fšr

Läs mer

Objektorienterad programmering i Java

Objektorienterad programmering i Java Objektorienterad programmering i Java Föreläsning 4 Täcker i stort sett kapitel 6 i kursboken Java Software Solutions 1 Läsanvisningar Den här föreläsningen är uppbyggd som en fortsättning av exemplet

Läs mer

Tentamen. Programmeringsmetodik, KV: Java och OOP. 17 januari 2002

Tentamen. Programmeringsmetodik, KV: Java och OOP. 17 januari 2002 Pedher Johansson Institutionen för datavetenskap LÖSNINGSFÖRSLAG Lösningsförslag Tentamen Programmeringsmetodik, KV: Java och OOP 17 januari 2002 Uppgift 1 (20 p) Teoriuppgifter Resultat och uppgifter

Läs mer

BST implementering, huvudstruktur

BST implementering, huvudstruktur BST implementering, huvudstruktur BST-implementering public class BinarySearchTree

Läs mer

Konstruktion av klasser med klasser

Konstruktion av klasser med klasser Konstruktion av klasser med klasser Klasser kan byggas på redan denierade klasser genom att klassobjekt används som dataattribut när en ny klass beskrivs. Exempel: Klassen PairOfDice har två attribut attribut

Läs mer

ITK:P1 Föreläsning 1. Programmering. Programmeringsspråket Java. Stark typning Explicit typning Strukturerat Hög säkerhet

ITK:P1 Föreläsning 1. Programmering. Programmeringsspråket Java. Stark typning Explicit typning Strukturerat Hög säkerhet ITK:P1 Föreläsning 1 Att programmera i språket Java DSV Peter Mozelius Programmering Olika typer av programmering som t ex: o Imperativ programmering (C, Pascal m fl) o Funktionell programmering (Lisp,

Läs mer

Föreläsning 2. Länkad lista och iterator

Föreläsning 2. Länkad lista och iterator Föreläsning 2 Länkad lista och iterator Föreläsning 2 Länkad-lista Lista implementerad med en enkellänkad lista Iterator Implementering av en Iterator Dubbellänkad lista och cirkulär lista LinkedList JCF

Läs mer

1 Uppgift 1. a) Skapar ett Company-objekt med hjälp av den överlagrade konstruktorn. Du kan själv välja värden på instansvariablerna.

1 Uppgift 1. a) Skapar ett Company-objekt med hjälp av den överlagrade konstruktorn. Du kan själv välja värden på instansvariablerna. 1 Uppgift 1 Klassen Company Banken FinanceTrust som tidigare bara haft privatpersoner som kunder vill nu bygga ut sitt datasystem så att även företag kan registreras som kunder. Skriv klassen Company som

Läs mer

Föreläsning 11 Innehåll

Föreläsning 11 Innehåll Föreläsning 11 Innehåll Sortering O(n 2 )-algoritmer: urvalssortering insättningssortering O(n log n)-algoritmer: Mergesort Quicksort Heapsort behandlades i samband med prioritetsköer. Undervisningsmoment:

Läs mer

Arv: Fordonsexempel. Arv. Arv: fordonsexempel (forts) Arv: Ett exempel. En klassdefinition class A extends B {... }

Arv: Fordonsexempel. Arv. Arv: fordonsexempel (forts) Arv: Ett exempel. En klassdefinition class A extends B {... } En klassdefinition class A extends B {... Arv definierar en klass A som ärver av B. Klassen A ärver alla fält och metoder som är definierade för B. A är en subklass till B. B är en superklass till A. class

Läs mer

Interface. Interface. Tobias Wrigstad (baserat på bilder från Tom Smedsaas) 3 december 2010

Interface. Interface. Tobias Wrigstad (baserat på bilder från Tom Smedsaas) 3 december 2010 Tobias Wrigstad (baserat på bilder från Tom Smedsaas) 3 december 2010 interface, motivation och bakgrund Antag att vi gör en generell listklass: public class List { protected static class ListNode { public

Läs mer

Del A (obligatorisk för alla)

Del A (obligatorisk för alla) Del A (obligatorisk för alla) A1. Ringa in rätt svarsalternativ eller skriv svar i ruta om sådan a) Satsen double x = (int)(1 + 3/2.0) + 3.; resulterar i b) Satsen int x = (int)(1 + 3/2.0) + 3.; resulterar

Läs mer

Föreläsning Datastrukturer (DAT036)

Föreläsning Datastrukturer (DAT036) Föreläsning Datastrukturer (DAT036) Nils Anders Danielsson 2013-11-25 Idag Starkt sammanhängande komponenter Duggaresultat Sökträd Starkt sammanhängande komponenter Uppspännande skog Graf, och en möjlig

Läs mer

Föreläsning 3. Stack

Föreläsning 3. Stack Föreläsning 3 Stack Föreläsning 3 ADT Stack Stack JCF Tillämpning Utvärdera ett postfix uttryck Stack implementerad med en array Stack implementerad med en länkad lista ADT Stack Grundprinciper: En stack

Läs mer

DAT043 Objektorienterad Programmering

DAT043 Objektorienterad Programmering DAT043 Objektorienterad Programmering Detta är en exempeltenta som innehåller gamla tentauppgifter av ungefär liknande slag som ni kan förvänta er se på ordinarie tenta i Del 1 respektive Del 2. Dock är

Läs mer

Laboration 3, uppgift En klass för en räknare

Laboration 3, uppgift En klass för en räknare Laboration 3, uppgift 1 3.1 En klass för en räknare Ursprungligen skriven av Erland Holmström. Magnus Myreen har uppdaterat vissa delar. Hösten 2014 Anvisningar: Programmet skall utformas enligt de principer

Läs mer

OOP Omtenta 2010-03-06 10.00 15.00

OOP Omtenta 2010-03-06 10.00 15.00 Stockholms universitet 1 (6) OOP OOP Omtenta 2010-03-06 10.00 15.00 Avser kurserna: DSK1:OOP GES:OOP ID1013 Anvisningar Påbörja varje ny uppgift på nytt blad. Skriv endast på ena sidan av bladen. Skriv

Läs mer

Länkade strukturer, parametriserade typer och undantag

Länkade strukturer, parametriserade typer och undantag Länkade strukturer, parametriserade typer och undantag Programmering för språkteknologer 2 Sara Stymne 2013-09-18 Idag Parametriserade typer Listor och länkade strukturer Komplexitet i länkade strukturer

Läs mer

Tentamen, EDAA01 Programmeringsteknik fördjupningskurs

Tentamen, EDAA01 Programmeringsteknik fördjupningskurs LUNDS TEKNISKA HÖGSKOLA 1(5) Institutionen för datavetenskap Tentamen, EDAA01 Programmeringsteknik fördjupningskurs 2014 03 10, 8.00 13.00 Anvisningar: Denna tentamen består av 5 uppgifter. Preliminärt

Läs mer

Objektorienterad programmering E. Back to Basics. En annan version av printtable. Ett enkelt exempel. Föreläsning 10

Objektorienterad programmering E. Back to Basics. En annan version av printtable. Ett enkelt exempel. Föreläsning 10 Objektorienterad programmering E Föreläsning 10 Rekursion Länkade datastrukturer Back to Basics Exekvera programmet för hand! public class Param { public static int f(int x) { return x+1; public static

Läs mer

Samlingar, Gränssitt och Programkonstruktion! Förelasning 11!! TDA540 Objektorienterad Programmering!

Samlingar, Gränssitt och Programkonstruktion! Förelasning 11!! TDA540 Objektorienterad Programmering! Samlingar, Gränssitt och Programkonstruktion! Förelasning 11!! TDA540 Objektorienterad Programmering! Samlingar Vi kommer att behöva hantera samlingar av objekt - Har oftast använd Array (fält) - Bra om

Läs mer

Ett problem. Kontrollstrukturer och arrayer. Arrayer. Lösningen. Arrayer och hakparanteser. Exempel int[] results; results = new int[10]; // 0..

Ett problem. Kontrollstrukturer och arrayer. Arrayer. Lösningen. Arrayer och hakparanteser. Exempel int[] results; results = new int[10]; // 0.. Ett problem Kontrollstrukturer och er Hur sparas data T ex när man vill spara resultaten av en tävling Exempel med 3 deltagare: public class Competition private int result1; private int result2; private

Läs mer

if (n==null) { return null; } else { return new Node(n.data, copy(n.next));

if (n==null) { return null; } else { return new Node(n.data, copy(n.next)); Inledning I bilagor finns ett antal mer eller mindre ofullständiga klasser. Klassen List innehåller några grundläggande komponenter för att skapa och hantera enkellänkade listor av heltal. Listorna hålls

Läs mer

OBJEKTORIENTERAD PROGRAMVARUUTVECKLING

OBJEKTORIENTERAD PROGRAMVARUUTVECKLING Institutionen för Data- och informationsteknik TENTAMEN OBJEKTORIENTERAD PROGRAMVARUUTVECKLING OBS! Det kan finnas kurser med samma eller liknande namn på olika utbildningslinjer. Denna tentamen gäller

Läs mer

Föreläsning 12. Länkade listor

Föreläsning 12. Länkade listor Föreläsning 12 Länkade listor Jämför en array med en länkad lista m in n e t Array (med 5 element): + effektiv vid hämtning - ineffektiv vid insättning och borttagning Länkad lista (med 5 element): + effektiv

Läs mer

Tentamen Datastrukturer (DAT036/DAT037/DIT960)

Tentamen Datastrukturer (DAT036/DAT037/DIT960) Tentamen Datastrukturer (DAT036/DAT037/DIT960) Datum och tid för tentamen: 2016-04-07, 14:00 18:00. Författare: Nils Anders Danielsson. (Tack till Per Hallgren och Nick Smallbone för feedback.) Ansvarig:

Läs mer

Lägg uppgifterna i ordning. Skriv uppgiftsnummer och din kod överst i högra hörnet på alla papper.

Lägg uppgifterna i ordning. Skriv uppgiftsnummer och din kod överst i högra hörnet på alla papper. Tentamen Programmeringsteknik II 2017-10-23 Skrivtid: 14:00 19:00 Tänk på följande Lägg uppgifterna i ordning. Skriv uppgiftsnummer och din kod överst i högra hörnet på alla papper. Fyll i försättssidan

Läs mer

Datastrukturer. Föreläsning 5. Maps 1

Datastrukturer. Föreläsning 5. Maps 1 Datastrukturer Föreläsning 5 Maps 1 Traversering av träd Maps 2 Preordningstraversering Traversera = genomlöpa alla noderna i ett träd Varje nod besöks innan sina delträd Preordning = djupet först Exempel:

Läs mer

Länkade strukturer. (del 2)

Länkade strukturer. (del 2) Länkade strukturer (del 2) Översikt Abstraktion Dataabstraktion Inkapsling Gränssnitt (Interface) Abstrakta datatyper (ADT) Programmering tillämpningar och datastrukturer 2 Abstraktion Procedurell abstraktion

Läs mer

Objektorienterad programmering i Java Undantag Sven-Olof Nyström Uppsala Universitet Skansholm: Kapitel 11

Objektorienterad programmering i Java Undantag Sven-Olof Nyström Uppsala Universitet Skansholm: Kapitel 11 Objektorienterad programmering i Java Undantag Sven-Olof Nyström Uppsala Universitet Skansholm: Kapitel 11 Undantag Engelska: exceptions Skansholm: exceptionella händelser Fel som genereras om man försöker

Läs mer

DI-institutionen Sid 1 av 6 Hans-Edy Mårtensson Sten Sundin

DI-institutionen Sid 1 av 6 Hans-Edy Mårtensson Sten Sundin DI-institutionen Sid 1 av 6 Hans-Edy Mårtensson Sten Sundin TENTAMEN I IKB007 INTERNETPROGRAMMERING MED JAVA för SY2 1999-03-17, kl 14.00-18.00 Hjälpmedel: En lärobok i Java programmering Återlämningstillfälle:

Läs mer

Abstrakta datatyper. Primitiva vektorer. Deklarera en vektor

Abstrakta datatyper. Primitiva vektorer. Deklarera en vektor Abstrakta datatyper 1 Primitiva vektorer Vektorer kan skapas av primitiva datatyper, objektreferenser eller andra vektorer. Vektorer indexeras liksom i C från 0. För att referera en vektor används hakparenteser.

Läs mer

Exempel. Arrayer. Lösningen. Ett problem. Arrayer och hakparanteser. Arrayer

Exempel. Arrayer. Lösningen. Ett problem. Arrayer och hakparanteser. Arrayer Exempel for (int antal=; antal < 75; antal++) System.out.println (antal); Arrayer for (int num=5; num

Läs mer

Rekursion. Att tänka rekursivt Att programmera rekursivt i Java Exempel. Programmeringsmetodik -Java 254

Rekursion. Att tänka rekursivt Att programmera rekursivt i Java Exempel. Programmeringsmetodik -Java 254 Rekursion Rekursion är en grundläggande programmeringsteknik M h a rekursion kan vissa problem lösas på ett mycket elegant sätt Avsnitt 11 i kursboken: Att tänka rekursivt Att programmera rekursivt i Java

Läs mer

Tentamen. Datalogi I, grundkurs med Java 10p, 2D4112, Lördagen den 30 november 2002 kl , salar E33, E34

Tentamen. Datalogi I, grundkurs med Java 10p, 2D4112, Lördagen den 30 november 2002 kl , salar E33, E34 Tentamen Datalogi I, grundkurs med Java 10p, 2D4112, 2002-2003 Lördagen den 30 november 2002 kl 9.00 14.00, salar E33, E34 Inga hjälpmedel 30 poäng ger säkert godkänt, 40 poäng ger betyg 4 50 poäng ger

Läs mer

ADT Kö. Seminarium 4 Köer och Stackar Innehåll. Operationer. ADT Stack. Definition. Definition

ADT Kö. Seminarium 4 Köer och Stackar Innehåll. Operationer. ADT Stack. Definition. Definition Seminarium 4 Köer och Stackar Innehåll ADT:erna Kö och Stack Definitioner Operationer Exempel på användning Givna klasser i Java Interfacet Queue Klassen Stack Klassen LinkedList Klassen PriorityQueue

Läs mer

Idag. statiska metoder och variabler. private/public/protected. final, abstrakta klasser, gränssnitt, delegering. wrapper classes

Idag. statiska metoder och variabler. private/public/protected. final, abstrakta klasser, gränssnitt, delegering. wrapper classes Idag statiska metoder och variabler private/public/protected final, abstrakta klasser, gränssnitt, delegering wrapper classes ett lite större exempel Objectorienterad programmering Sida 1 Vad vi vet om

Läs mer

Föreläsning 7. Träd och binära sökträd

Föreläsning 7. Träd och binära sökträd Föreläsning 7 Träd och binära sökträd Föreläsning 7 Träd Binära träd Binärt sökträd som ADT Implementering av binärt sökträd Travestera binärt sökträd Sökning Insättning/borttagning Det är extra mycket

Läs mer

DAT043 - föreläsning 8

DAT043 - föreläsning 8 DAT043 - föreläsning 8 Paket, generics, Java collections framework 2017-02-07 Paket och tillgänglighet Ovanför klasser finns en hierarkisk namespace med paket. Filer som inte deklareras i något paket finns

Läs mer

LULEÅ TEKNISKA UNIVERSITET

LULEÅ TEKNISKA UNIVERSITET LULEÅ TEKNISKA UNIVERSITET Tentamen i Objektorienterad programmering och design Totala antalet uppgifter: 5 Lärare: Håkan Jonsson, Andrey Kruglyak, 491000 Resultatet offentliggörs senast: 2010-04-09. Tillåtna

Läs mer

Objektorienterad Programkonstruktion, DD1346. Tentamen , kl

Objektorienterad Programkonstruktion, DD1346. Tentamen , kl Skolan för datavetenskap och kommunikation Objektorienterad Programkonstruktion, DD1346 Tentamen 2016 03 18, kl. 14.00 17.00 Tillåtna hjälpmedel: Papper, penna och radergummi. Notera: Frågorna i del I

Läs mer

Föreläsning 9. Sortering

Föreläsning 9. Sortering Föreläsning 9 Sortering Föreläsning 9 Sortering Sortering och Java API Urvalssortering Instickssortering Söndra och härska Shellsort Mergesort Heapsort Quicksort Bucketsort Radixsort Läsanvisningar och

Läs mer

Listor. Koffman & Wolfgang kapitel 2, avsnitt , och 2.9

Listor. Koffman & Wolfgang kapitel 2, avsnitt , och 2.9 Listor Koffman & Wolfgang kapitel 2, avsnitt 2.1 2.3, 2.5 2.6 och 2.9 Figur 2.1, sid 63 java.util.list, med dess implementeringar 2 List och primitiva typer En array kan innehålla primitiva typer: int[],

Läs mer

Tentamen. 2D4135 vt 2005 Objektorienterad programmering, design och analys med Java Lördagen den 28 maj 2005 kl 9.00 14.

Tentamen. 2D4135 vt 2005 Objektorienterad programmering, design och analys med Java Lördagen den 28 maj 2005 kl 9.00 14. Tentamen 2D4135 vt 2005 Objektorienterad programmering, design och analys med Java Lördagen den 28 maj 2005 kl 9.00 14.00, sal E33 Tentan har en teoridel och en problemdel. På teoridelen är inga hjälpmedel

Läs mer

Abstrakt datatyp. -Algoritmer och Datastrukturer- För utveckling av verksamhet, produkter och livskvalitet.

Abstrakt datatyp. -Algoritmer och Datastrukturer- För utveckling av verksamhet, produkter och livskvalitet. -Algoritmer och Datastrukturer- Abstrakt datatyp Datatyp för en variabel Betecknar i ett programmeringsspråk den mängd värden variabeln får anta. T ex kan en variabel av typ boolean anta värdena true och

Läs mer

TDDE10 m.fl. Objektorienterad programmering i Java Föreläsning 6 Erik Nilsson, Institutionen för Datavetenskap, LiU

TDDE10 m.fl. Objektorienterad programmering i Java Föreläsning 6 Erik Nilsson, Institutionen för Datavetenskap, LiU TDDE10 m.fl. Objektorienterad programmering i Java Föreläsning 6 Erik Nilsson, Institutionen för Datavetenskap, LiU På denna föreläsning: Mer om Interface Generiska klasser Undantag Nästlade klasser 1

Läs mer

Föreläsning Datastrukturer (DAT036)

Föreläsning Datastrukturer (DAT036) Föreläsning Datastrukturer (DAT036) Nils Anders Danielsson 2012-11-05 Repetition Förra gången: Listor, stackar, köer. Länkade listor, pekarjonglering. Idag: Cirkulära arrayer. Dynamiska arrayer. Amorterad

Läs mer

Föreläsning 4. ADT Kö Kö JCF Kö implementerad med en cirkulär array Kö implementerad med en länkad lista

Föreläsning 4. ADT Kö Kö JCF Kö implementerad med en cirkulär array Kö implementerad med en länkad lista Föreläsning 4 Kö Föreläsning 4 ADT Kö Kö JCF Kö implementerad med en cirkulär array Kö implementerad med en länkad lista ADT Kö Grundprinciper: En kö fungerar som en kö. Man fyller på den längst bak och

Läs mer

Objektorienterad programmering E. Algoritmer. Telefonboken, påminnelse (och litet tillägg), 1. Telefonboken, påminnelse (och litet tillägg), 2

Objektorienterad programmering E. Algoritmer. Telefonboken, påminnelse (och litet tillägg), 1. Telefonboken, påminnelse (och litet tillägg), 2 Objektorienterad programmering E Algoritmer Linjär sökning Binär sökning Tidsuppskattningar Föreläsning 9 Vad behöver en programmerare kunna? (Minst) ett programspråk; dess syntax och semantik, bibliotek

Läs mer

Klasshierarkier - repetition

Klasshierarkier - repetition Klasshierarkier - repetition Klasser kan byggas på redan denierade klasser, egna och/eller färdigskrivna, genom: I att klassobjekt används som attribut (instansvariabler): har-relation. Exempel: traksystemet

Läs mer

Lösningsförslag till exempeltenta 1

Lösningsförslag till exempeltenta 1 Lösningsförslag till exempeltenta 1 1 1. Beskriv hur binärsökning fungerar. Beskriv dess pseudokod och förklara så klart som möjligt hur den fungerar. 2 Uppgift 1 - Lösning Huvudidé: - Titta på datan i

Läs mer

Tentamen i Algoritmer & Datastrukturer i Java

Tentamen i Algoritmer & Datastrukturer i Java Tentamen i Algoritmer & Datastrukturer i Java Hjälpmedel: Skrivhjälpmedel, miniräknare. Ort / Datum: Halmstad / 2008-05-27 Skrivtid: 4 timmar Kontakt person: Nicolina Månsson, tel. 035-167487 Poäng / Betyg:

Läs mer

TDDC30. Objektorienterad programmering i Java, datastrukturer och algoritmer. Föreläsning 4 Erik Nilsson, Institutionen för Datavetenskap, LiU

TDDC30. Objektorienterad programmering i Java, datastrukturer och algoritmer. Föreläsning 4 Erik Nilsson, Institutionen för Datavetenskap, LiU TDDC30 Objektorienterad programmering i Java, datastrukturer och algoritmer. Föreläsning 4 Erik Nilsson, Institutionen för Datavetenskap, LiU På denna föreläsning: Interface Generiska klasser Undantag

Läs mer