Tabelbegrebet. Klassediagrammer (III) Oversigt. Anvendelse af Tabeller. Tabeller og qualified associations

Størrelse: px
Starte visningen fra side:

Download "Tabelbegrebet. Klassediagrammer (III) Oversigt. Anvendelse af Tabeller. Tabeller og qualified associations"

Transkript

1 Tabelbegrebet Klassediagrammer (III) Tabeller og qualified associations originally by Michael R. Hansen modified/extended by Anne E. Haxthausen Informatics and Mathematical Modelling Technical University of Denmark En tabel fra en mængde A til en mængde B, er en endelig delmængde A 1 af A og en funktion t: A 1 B En tabel vises ofte på tabular form: a 1 b 1 a 2 b 2 A 1 = a 1,...,a n.. t(a i ) = b i, for 1 i n a n b n Oversigt Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p. 1 A 1 kaldes t s domæne a i A 1 kaldes en nøgle b i = t(a i ) kaldes en værdi (a i,b i ) kaldes en indgang Anvendelse af Tabeller Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p. 3 Tabelbegrebet Modellering med qualified associations og tabeller Implementering af tabeller (Java Maps, HashMaps) For mange anvendelser findes naturlige nøgler: Studienummer Kursusnummer CPR nummer Varekoder Medlemsnumre En kursushåndbog kan, for eksempel, modelleres som en tabel fra kursusnumre til kursusbeskrivelser. Tabeller er nyttige som modelleringsredskab. Tabeller understøttes af gode programbiblioteker Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p. 4

2 Studiehåndbog: Modellering (I) Java: Tabel-Interfacet Map<K,V> En studiehåndbog beskriver en samling kurser, hvor hvert kursus beskrives ved et nummer, skemaplacering, formål, forudsætningskurser, osv. Håndbog * Kursus -nr: int -beskrivelse: String ikke synligt at et kursus er entydigt bestemt ved et kursusnummer utilfredsstillende modellering int size() : A 1 boolean containskey(k k) : k A 1 V get(k k) : t(k), hvis k A 1, og null ellers V put(k k, V v) : A 1 = A 1 k, t (k 1 ) = v hvis k = k 1 t(k 1 ) ellers returnerer t(k), hvis k A 1, og ellers null hvor t : A B og A 1 A er tabellen før operationen og t : A B og A 1 A er tabellen efter, hvis der er sidevirkning. Studiehåndbog: Modellering (II) Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p. 7 Java: Tabel Implementering HashMap<K,V> En studiehåndbog beskriver en samling kurser, hvor hvert kursus er entydigt bestemt ved et nummer, og.... Modelleres vha en kvalificeret (eng. qualified) association en håndbog har 0-1 kursus for hvert nummer Håndbog 0..1 nr: Integer Kursus -beskrivelse: String Den kvalificerede association kan realiseres ved at Håndbog kan indeholde en tabel, hvor numre er nøgler, og kurser er værdier I klassebiblioteket for Java findes der klasser, der implementer Map<K,V> interfacet: bl.a. klassen HashMap<K,V>, der som datastruktur bruger såkaldte hashtabeller. I algoritmer og datastrukturer vil I lære om hashtabeller. Eksempel: Map<Integer,Kursus> katalog = new HashMap<Integer,Kursus>(); katalog.put(2161, new Kursus(...)); Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p. 8

3 Klasse: Haandbog operationer på håndbogen implementeres direkte ved HashMap-operationer import java.util.*; public class Haandbog private Map<Integer,Kursus> katalog; public Haandbog() katalog = new HashMap<Integer,Kursus>(); public void opret(int nr, Kursus k) katalog.put(nr, k); public Kursus find(int nr) return katalog.get(nr); Hovedprogram Kursus k3333 = new Kursus("Programmering", "Java, C++, UML"); Kursus k4444 = new Kursus("Matematik", "Funktioner, relationer"); Kursus k5555 = new Kursus("Fysik", "Newtons love"); Kursus k6666 = new Kursus("Kemi", "Gasser"); Haandbog hb = new Haandbog(); hb.opret(3333,k3333); hb.opret(4444,k4444); hb.opret(5555,k5555); hb.opret(6666,k6666); System.out.println( hb ); public String tostring() return "" + katalog; System.out.println( hb.find(4444)); Klasse: Kurser Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p. 9 Udskrift Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p. 11 public class Kursus private String navn; private String indhold; public Kursus(String n, String i) navn = n; indhold = i; public String tostring() return "Navn: " + navn + "\n" + indhold + "\n"; 3333=Navn: Programmering Java, C++, UML, 4444=Navn: Matematik Funktioner, relationer, 6666=Navn: Kemi Gasser, 5555=Navn: Fysik Newtons love Navn: Matematik Funktioner, relationer Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p. 12

4 KasseApparat: Problemstilling Klassediagram Et elektronisk kasseapparat indeholder et katalog, hvor navn og pris for en vare knyttes sammen med en varekode. Et indkøb består at en række punkter, hvor det angives hvor mange styk af en given vare der købes. En regning skal beskrive enkeltindkøb af varer og angive en totalpris. Katalog +opret(in k : int, in vb : VareBeskrivelse) : void +find(in k : int) : VareBeskrivelse +pris(in k : int) : int +navn (in k : int) : String Kode:Integer 0..1 VareBeskrivelse -navn : String -pris : int Koeb +nyt(in k : int, in a : int) : void +regning(in kat : Katalog) : String Kode:Integer 0..1 Integer KasseApparat: Problemstilling Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p. 13 KasseApparat: Hovedprogram Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p. 15 Et elektronisk kasseapparat indeholder et katalog, hvor navn og pris for en vare knyttes sammen med en varekode. Et indkøb består at en række punkter, hvor det angives hvor mange styk af en given vare der købes. En regning skal beskrive enkeltindkøb af varer og angive en totalpris. Opret varekatalog og indkøb, og udskriv regning Katalog katalog = new Katalog(); katalog.opret(1, new VareBeskrivelse("is", 10)); katalog.opret(2, new VareBeskrivelse("fisk", 20)); Koeb koeb = new Koeb(1, 3); koeb.nyt(2, 4); koeb.nyt(1, 3); System.out.println(koeb.regning(katalog)); Udskrift: 4 fisk : 80 6 is : 60 Total = Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p. 16

5 Klasse: VareBeskrivelse Klasse: Koeb (I) public class VareBeskrivelse private String navn; private int pris; public VareBeskrivelse(String n, int p) navn = n; pris = p; public int getpris() return pris; public String getnavn() return navn; public String tostring() return navn + " koster " + pris + " kr."; Klasse: Katalog Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p. 17 public class Koeb private Map<Integer,Integer> map; public Koeb() map = new HashMap<Integer,Integer>(); public Koeb(int k, int a) map = new HashMap<Integer,Integer>(); map.put(k, a); public void nyt(int k, int a) int i = a; if (map.containskey(k)) i += (map.get(k)); map.put(k, i); public String tostring() return map + ""; Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p. 19 Java interfacet Set<E> public class Katalog private Map<Integer,VareBeskrivelse> map; public Katalog() map = new HashMap<Integer,VareBeskrivelse>(); Sidste gang så i Java interfacet Collection<E>. Set<E> er et subinterface af Collection<E> public void opret(int k, VareBeskrivelse vb) map.put(k, vb); public VareBeskrivelse find(int k) throws KatalogException if (! map.containskey(k)) throw new KatalogException(" findes ikke"); return map.get(k); public int pris(int k) return (map.get(k)).getpris(); public String navn(int k) return (map.get(k)).getnavn(); public String tostring() return "" + map; Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p. 20

6 Mere om Java interfacet Map<K,V> Klasse: Koeb (IIb) Endnu en tabel operation: Set< Map.Entry<K,V> > entryset() returnerer mængden af indgange i tabellen. Hver indgang har typen Map.Entry<K,V>. Map.Entry<K,V> er et interface for tabelindgange. Har to operationer: K getkey() V getvalue() public String regning(katalog kat) int total = 0; int a = 0; int p = 0; int k; String res = ""; for (Map.Entry<Integer,Integer> entry : map.entryset()) k = entry.getkey(); //varekode a = entry.getvalue(); //antal p = a * kat.pris(k); total += p; res += a + "\t" + kat.navn(k) + "\t : \t " + p + "\n"; return res + "Total = " + total; Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p. 23 Klasse: Koeb (IIa) Opsummering For at lave en regning skal alle tabelindgange i et indkøb behandles. Vi ønsker derfor at iterere over samlingen af tabelindgange. Givet en indkøbstabel i Map<Integer,Integer> map. Da vil map.entryset() returnerer en samling (eng. collection) af tabelindgange: Set< Map.Entry<Integer,Integer> > map.entryset() Modellering vha tabeller Implementering vha Maps mange operationer i en model kan ofte direkte implementeres ved operationer i tabelbiblioteker der findes mange effektive implementeringer af tabeller kurser i Algoritmer og Datastrukturer Elementerne har type Map.Entry<Integer,Integer>. På denne type findes to operationer: Integer getkey() Integer getvalue() Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p Software Engineering 1 c Michael R. Hansen og Anne E. Haxthausen, Spring 2009 p. 24

Opgaven fortsat. Opfølgning på Opgave 2 og Use Cases. Opgaven. Trin 1: Væsentlige begreber. Resultatliste: 100 bryst, herrer

Opgaven fortsat. Opfølgning på Opgave 2 og Use Cases. Opgaven. Trin 1: Væsentlige begreber. Resultatliste: 100 bryst, herrer Opfølgning på Opgave 2 og Use Cases originally by Michael R. Hansen modified/extended by Anne E. Haxthausen Informatics and Mathematical Modelling Technical University of Denmark Opgaven fortsat Efter

Læs mere

Løsning af møntproblemet

Løsning af møntproblemet Løsning af møntproblemet Keld Helsgaun RUC, oktober 1999 Antag at tilstandene i problemet (stillingerne) er repræsenteret ved objekter af klassen State. Vi kan da finde en kortest mulig løsning af problemet

Læs mere

Forelæsning Uge 3 Mandag

Forelæsning Uge 3 Mandag Forelæsning Uge 3 Mandag ArrayList Collection med variabelt antal elementer Der er mange andre Collection typer (se Collection interfacet i JavaDoc) MusicOrganizer projektet Eksempel på brug af ArrayList

Læs mere

Kursus i OOP og Java. Kursus i Objektorienteret programmering i Java

Kursus i OOP og Java. Kursus i Objektorienteret programmering i Java Kursus i OOP og Java Kursus i Objektorienteret programmering i Java Åben Dokumentlicens Dette foredragsmateriale er under Åben Dokumentlicens (ÅDL) Du har derfor lov til frit at kopiere dette værk Bruger

Læs mere

Design by Contract. Design and Programming by Contract. Oversigt. Prædikater

Design by Contract. Design and Programming by Contract. Oversigt. Prædikater Design by Contract Design and Programming by Contract Anne Haxthausen [email protected] Informatics and Mathematical Modelling Technical University of Denmark Design by Contract er en teknik til at specificere

Læs mere

AAU, Programmering i Java Intern skriftlig prøve 18. maj 2007

AAU, Programmering i Java Intern skriftlig prøve 18. maj 2007 AAU, Programmering i Java Intern skriftlig prøve 18. maj 2007 Opgavebesvarelsen skal afleveres som enten en printerudskrift eller som et passende dokument sendt via email til [email protected]. Besvarelsen skal

Læs mere

Eksempel på en database: studenter, kurser, eksamener

Eksempel på en database: studenter, kurser, eksamener Udvidet Programmering 1999 Forelæsning 20, fredag 12. november 1999 Relationsdatabaser: relationer, tupler, attributter Forespørgselssproget SQL Databasesystemet PostgreSQL Tilgang til relationsdatabaser

Læs mere

BRP 6.9.2006 Kursusintroduktion og Java-oversigt

BRP 6.9.2006 Kursusintroduktion og Java-oversigt BRP 6.9.2006 Kursusintroduktion og Java-oversigt 1. Kursusintroduktion 2. Java-oversigt (A): Opgave P4.4 3. Java-oversigt (B): Ny omvendings -opgave 4. Introduktion til næste kursusgang Kursusintroduktion:

Læs mere

Databaseadgang fra Java

Databaseadgang fra Java Databaseadgang fra Java Grundlæggende Programmering med Projekt Peter Sestoft Fredag 2007-11-23 Relationsdatabasesystemer Der er mange databaseservere Microsoft Access del af Microsoft Office MySQL god,

Læs mere

Abstrakte datatyper C#-version

Abstrakte datatyper C#-version Note til Programmeringsteknologi Akademiuddannelsen i Informationsteknologi Abstrakte datatyper C#-version Finn Nordbjerg 1/9 Abstrakte Datatyper Denne note introducerer kort begrebet abstrakt datatype

Læs mere

Hvem er vi? Kursus Introduktion. Kursuslærerne. Agenda for i dag

Hvem er vi? Kursus Introduktion. Kursuslærerne. Agenda for i dag Hvem er vi? Kursus Introduktion Anne Haxthausen [email protected] Informatics and Mathematical Modelling Technical University of Denmark 100 studerende med forskellig baggrund: software teknologi It og Kom

Læs mere

DM502. Peter Schneider-Kamp ([email protected]) http://imada.sdu.dk/~petersk/dm502/

DM502. Peter Schneider-Kamp (petersk@imada.sdu.dk) http://imada.sdu.dk/~petersk/dm502/ DM502 Peter Schneider-Kamp ([email protected]) http://imada.sdu.dk/~petersk/dm502/ 1 DM502 Bog, ugesedler og noter De første øvelser Let for nogen, svært for andre Kom til øvelserne! Lav opgaverne!

Læs mere

Skriftlig eksamen i Datalogi

Skriftlig eksamen i Datalogi Roskilde Universitetscenter side 1 af 9 sider Skriftlig eksamen i Datalogi Modul 1 Vinter 1999/2000 Opgavesættet består af 6 opgaver, der ved bedømmelsen tillægges følgende vægte: Opgave 1 5% Opgave 2

Læs mere

Kursus navn: Indledende programmering Kursus nr. 02101

Kursus navn: Indledende programmering Kursus nr. 02101 Danmarks Tekniske Universitet Side 1 af 8 sider Skriftlig prøve, den 15. december 2007 Kursus navn: Indledende programmering Kursus nr. 02101 Tilladte hjælpemidler: Alle skriftlige hjælpemidler Vægtning

Læs mere

DM507 Algoritmer og datastrukturer

DM507 Algoritmer og datastrukturer DM507 Algoritmer og datastrukturer Forår 2018 Projekt, del II Institut for matematik og datalogi Syddansk Universitet 20. marts, 2019 Dette projekt udleveres i tre dele. Hver del har sin deadline, således

Læs mere

DM507 Algoritmer og datastrukturer

DM507 Algoritmer og datastrukturer DM507 Algoritmer og datastrukturer Forår 2018 Projekt, del II Institut for matematik og datalogi Syddansk Universitet 13. marts, 2018 Dette projekt udleveres i tre dele. Hver del har sin deadline, således

Læs mere

DANMARKS TEKNISKE UNIVERSITET

DANMARKS TEKNISKE UNIVERSITET DANMARKS TEKNISKE UNIVERSITET Skriftlig prøve, 14. december 2018, 4 timer Side 1 af 18 Kursus navn: 02101 Indledende Programmering Kursus : 02101 Tilladte hjælpemidler: Ikke-digitale skriftlige hjælpemidler

Læs mere

Hashing og hashtabeller

Hashing og hashtabeller Datastrukturer & Algoritmer, Datalogi C Forelæsning 12/11-2002 Hashing og hashtabeller Teknik til at repræsentere mængder Konstant tid for finde og indsætte men ingen sortering af elementerne Specielt

Læs mere

Videregående programmering i Java

Videregående programmering i Java Videregående programmering i Java Dag 6 Komponenter (og lidt Swing og MVC) Læsning: VP 4, evt. VP 6 Dette materiale er under Åben Dokumentlicens, se http://www.sslug.dk/linuxbog/licens.html Grafiske komponenter

Læs mere

Videregående Programmering Obligatorisk opgave - 3. semester, efterår 2004

Videregående Programmering Obligatorisk opgave - 3. semester, efterår 2004 Overvågningssystem Beskrivelse Bagagesorteringssystemet består af et antal skranker (check-in) til modtagelse og registrering af bagage, et automatiseret sorteringsanlæg samt et antal terminaler (gates),

Læs mere

University of Southern Denmark Syddansk Universitet. DM502 Forelæsning 3

University of Southern Denmark Syddansk Universitet. DM502 Forelæsning 3 DM502 Forelæsning 3 Indlæsning fra tastatur Udskrift til skærm Repetition Beregning af middelværdi Gentagelse med stop-betingelse (while) Heltalsdivision Division med nul Type-casting ( (double) ) Betinget

Læs mere

University of Southern Denmark Syddansk Universitet. DM503 Forelæsning 11

University of Southern Denmark Syddansk Universitet. DM503 Forelæsning 11 DM503 Forelæsning 11 Generics Pakker Exceptions Indhold Generics Nedarvning og Generics Generics Nedarvning og Generics Husk Box fra sidst Generics public class Box {! private T object;! public void

Læs mere

Virkefeltsregler i Java

Virkefeltsregler i Java Virkefeltsregler i Java int i; int k; Sequence s; int j; What s in a name? Brian spillede blændende i søndags! Skolen ligger i Viby Ring til Kirsten og sig at... Et navn fortolkes i en kontekst og konteksten

Læs mere

DM507 Algoritmer og datastrukturer

DM507 Algoritmer og datastrukturer DM507 Algoritmer og datastrukturer Forår 2019 Projekt, del I Institut for matematik og datalogi Syddansk Universitet 27. februar, 2019 Dette projekt udleveres i tre dele. Hver del har sin deadline, således

Læs mere

Objektorienterede metoder

Objektorienterede metoder Objektorienterede metoder Denne gang: Designmønstre Skabende designmønstre: Fabrikeringsmetode/Fabrik, Singleton, Abstrakt fabrik (Toolkit), Prototype, Objektpulje Singleton eksempel: Forskellige slags

Læs mere

Eksempel: et ordresystem note 5 Lagdeling s. 1

Eksempel: et ordresystem note 5 Lagdeling s. 1 Eksempel: et ordresystem note 5 Lagdeling s. 1 Eksempel: et ordre-system NiceHair er et firma, som sælger udstyr, inventar og frisørartikler til frisørsaloner over hele landet. Det er ejet af et ægtepar

Læs mere

University of Southern Denmark Syddansk Universitet. DM502 Forelæsning 2

University of Southern Denmark Syddansk Universitet. DM502 Forelæsning 2 DM502 Forelæsning 2 Repetition Kompilere og køre Java program javac HelloWorld.java java HeloWorld.java Debugge Java program javac -g HelloWorld.java jswat Det basale Java program public class HelloWorld

Læs mere

Ugeseddel 4 1. marts - 8. marts

Ugeseddel 4 1. marts - 8. marts Ugeseddel 4 1. marts - 8. marts Læs følgende sider i kapitel 6 i lærebogen: s. 233 258 og s. 291 317 (afsnit 6.3 overspringes). Begynd at overveje, hvad afleveringsopgaven skal omhandle. Læs vejledningen,

Læs mere

SWC eksamens-spørgsmål. Oversigt

SWC eksamens-spørgsmål. Oversigt SWC eksamens-spørgsmål Oversigt #1 Typer og variable #2 Aritmetik og logik #3 Klasser (definition, objekter) #4 Klasser (metoder) #5 Klasser (nedarvning, polymorfi) #6 Conditional statements #7 Repetition

Læs mere

Tree klassen fra sidste forelæsning

Tree klassen fra sidste forelæsning Programmering 1999 Forelæsning 12, fredag 8. oktober 1999 Oversigt Abstrakte klasser. Grænseflader. Programmering 1999 KVL Side 12-1 Tree klassen fra sidste forelæsning class Tree { int age; // in years

Læs mere

DM507 Algoritmer og datastrukturer

DM507 Algoritmer og datastrukturer DM507 Algoritmer og datastrukturer Forår 2016 Projekt, del I Institut for matematik og datalogi Syddansk Universitet 29. februar, 2016 Dette projekt udleveres i tre dele. Hver del har sin deadline, således

Læs mere

Om binære søgetræer i Java

Om binære søgetræer i Java Om binære søgetræer i Java Mads Rosendahl 7. november 2002 Resumé En fix måde at gemme data på er i en træstruktur. Måden er nyttig hvis man får noget data ind og man gerne vil have at det gemt i en sorteret

Læs mere

Dag 10 Flertrådet programmering

Dag 10 Flertrådet programmering Videregående programmering i Java Dag 10 Flertrådet programmering Fremlæggelse af programmering/status for projekter Dokumentation med javadoc Flertrådede designmønstre: Arbejdstråd, Producent Konsument,

Læs mere

DM507 Algoritmer og datastrukturer

DM507 Algoritmer og datastrukturer DM507 Algoritmer og datastrukturer Forår 2012 Projekt, del II Institut for matematik og datalogi Syddansk Universitet 15. marts, 2012 Dette projekt udleveres i tre dele. Hver del har sin deadline, således

Læs mere

Rekursion og dynamisk programmering

Rekursion og dynamisk programmering Rekursion og dynamisk programmering Datastrukturer & Algoritmer, Dat C Forelæsning 12/10-2004 Henning Christiansen Rekursion: at en procedure kalder sig selv eller et antal metoder kalder hinanden gensidigt.

Læs mere

Klasser og nedarvning

Klasser og nedarvning Datalogi C, Efterår 2004 OH er, forelæsning 21/9-2004 Klasser og nedarvning Hvad er formålet? Typer, generisk kode, typeparameterisering Kritisk kig på, hvordan man gør i Java. Opgaven til senere: Generalisere

Læs mere

Jacob Nordfalk. Ingeniørhøjskolen i København. Nykøbing F itvisioncenter 24. februar 2004

Jacob Nordfalk. Ingeniørhøjskolen i København. Nykøbing F itvisioncenter 24. februar 2004 Genbrugelige komponenter og designmønstre i Java Jacob Nordfalk Ingeniørhøjskolen i København Nykøbing F itvisioncenter 24. februar 2004 Program Om Jacob Nordfalk introduktion (ikke-teknisk del) Komponentbaseret

Læs mere

02101: Indledende programmering. IMM, Danmarks Tekniske Universitet. Læg en studieplan. Dato: 7/12-2007. Gruppenummer: 20

02101: Indledende programmering. IMM, Danmarks Tekniske Universitet. Læg en studieplan. Dato: 7/12-2007. Gruppenummer: 20 Kursus 02101: Indledende programmering. Michael Holm & Mikael Andersen side 1 af 136 Kursus: Institut: 02101: Indledende programmering IMM, Danmarks Tekniske Universitet. Titel: Læg en studieplan Dato:

Læs mere

Software Construction 1 semester (SWC) Spørgsmål 1

Software Construction 1 semester (SWC) Spørgsmål 1 Spørgsmål 1 Objekter #1 Giv en kort præsentation af begrebet objekt, samt hvorledes du erklærer(declare), opretter(create) og bruger objekter Du kan beskrive o Datatyper o Variable / Instans variable /

Læs mere

Videregående Programmering for Diplom-E Noter

Videregående Programmering for Diplom-E Noter Videregående Programmering for Diplom-E Noter 1. Uddelegering Ét af de væsentlige principper i objektorienteret programmering er, at enhver klasse selv skal kunne "klare ærterne". Enhver klasse skal altså

Læs mere

Grundlæggende Programmering ITU, Efterår 1999. Skriftlig eksamen i Grundlæggende Programmering

Grundlæggende Programmering ITU, Efterår 1999. Skriftlig eksamen i Grundlæggende Programmering Skriftlig eksamen i Grundlæggende Programmering ITU, 20. januar 2000 Alle hjælpemidler tilladt, dog ikke datamat. Eksamen er skriftlig, fire timer, og bedømmes efter 13-skalaen. Opgavesættet består af

Læs mere

Fundamentale sprogbegreber

Fundamentale sprogbegreber Fundamentale sprogbegreber Sætninger og udtryk Niveauer af programbeskrivelse (statisk versus dynamisk syn) Oversigt Sætninger simple sætninger (assignment, metodekald) sammensatte sætninger (selektion,

Læs mere

Kursus 02199: Programmering. Kontrol af programudførelsen. afsnit 3.1-3.5. if (indkomst > 267000) topskat = (indkomst-267000) * 0.

Kursus 02199: Programmering. Kontrol af programudførelsen. afsnit 3.1-3.5. if (indkomst > 267000) topskat = (indkomst-267000) * 0. Kursus 02199: Programmering afsnit 3.1-3.5 Anne Haxthausen IMM, DTU 1. Kontrol af programudførn (afsnit 3.1) 2. Valg-sætninger (if og switch) (afsnit 3.2 og 3.3) 3. Bloksætninger (afsnit 3.2) 4. Logiske

Læs mere

DATALOGI 0GB. Skriftlig eksamen tirsdag den 6. januar 2004

DATALOGI 0GB. Skriftlig eksamen tirsdag den 6. januar 2004 Københavns Universitet bacheloruddannelsen i datalogi side 1 af 6 DATALOGI 0GB Skriftlig eksamen tirsdag den 6. januar 2004 Dette opgavesæt består af 6 nummererede sider. Eksamensdeltagerne bør straks

Læs mere

Martin Olsen. DM507 Projekt Del I. 19. marts 2012 FOTO: Colourbox

Martin Olsen. DM507 Projekt Del I. 19. marts 2012 FOTO: Colourbox Martin Olsen DM0 Projekt 0 Del I. marts 0 FOTO: Colourbox Indhold Indledning... Opgave... Opgave... Opgave... Opgave... Opgave... Opgave... Opgave... Kildekode til SimpleInv.java... Kildekode til MergeSort.java...

Læs mere