Array&ArrayList Lagring Liste Klasseparametre Arrayliste Testing Lenkelister
|
|
|
- Emil Isaksen
- 7 år siden
- Visninger:
Transkript
1 Dagens tema Lister og generiske klasser, del I Array-er og ArrayList (Big Java 6.1 & 6.8) Ulike lagringsformer (Collection) i Java (Big Java 15.1) Klasser med typeparametre («generiske klasser») (Big Java 18) Lage vår egen ArrayList (Big Java 16.2) Lenkelister (Big Java 15.2)
2 Hva er en array Array-er 0 Navn: a Type: String[] En array er en sammenhengende gruppe celler i minnet. 4 Type: String[]
3 Hva er en array Hva er bra og mindre bra med arrayer u En god notasjon: kompakt og lettforståelig: a[i] = a[i+1] + "*"; u Tar liten plass u Raske Men... Vi må vite størrelsen når arrayen opprettes. Størrelsen er uforanderlig. d Kronglete å legge til nye verdier midt i arrayen.
4 Hva er så en ArrayList ArrayList-er void add(string) void set(int,string) Navn: a Type: ArrayList<String> String get(int) int size() ArrayList er en klasse i Java-biblioteket. Grensenittet er gitt men implementasjonen er ukjent. class ArrayList
5 Hva er så en ArrayList Er ArrayList noen ganger bedre enn arrayer u Vi trenger ikke vite størrelsen initielt. u Størrelsen kan endres underveis. u Enkelt å legge til nye elementer hvor som helst. Men... d Notasjonen er litt kronglete: a.set(i, a.get(i+1) + "*"); Ikke for primitive typer som int, char etc. 1 Tar mye mer plass. d Er langsommere i bruk. 1 Men innkapsling er en løsning. Vi kommer til det neste uke.
6 Hva gjør man i Python Hva gjør man i Python I Python har man valgt å bruke lister som er en mellomløsning: Enkel notasjon (som Javas arrayer) u Fleksibel størrelse (som Javas ArrayList) d Ikke så rask
7 Litt om plassbehov Er plassforbruket viktig Stort sett er programmets plassforbruk helt uvesentlig, men det finnes unntak: Hvis man trenger ekstremt mange objekter Hvis datamaskinen har veldig lite minne (for eksempel «Internet of things») Hvis hastigheten er avgjørende Konklusjon: Dette må vurderes når man starter et prosjekt.
8 Litt om hastighet Betyr hastighet noe En sammenligning basert på et program som bruker Javas arrayer og ArrayList og Pythons lister aktivt: Java array Java ArrayList Python liste 1,77 s 5,66 s 155,32 s Oftest er programmets kjøretid ikke spesielt viktig, men det finnes unntak: Når jobben er spesielt stor og tung Når man trenger øyeblikkelig respons Konklusjon: Dette må vurderes når man starter et prosjekt.
9 Hva er best av array og ArrayList Hva bør jeg velge i Java Velg array hvis du vet størrelsen på arrayen når den skal opprettes hastighet er viktig plass er viktig Velg ArrayList ellers.
10 Java støtter mange ulike former for datalagring Datalagring i Java Java-biblioteket tilbyr mange ulike former for lagring av data: Collection Map List Queue Set HashMap TreeMap ArrayList Stack LinkedList PriorityQueue HashSet TreeSet
11 Java støtter mange ulike former for datalagring Collection er en samling av alle lagringsformene. List er en sekvensiell samling. ArrayList er en List implementert med en array. Stack ser på elementene som en stakk. LinkedList er en List implementert som en lenkeliste. Queue lagrer i køordning. PriorityQueue lagrer i en sortert kø. Set lagrer uten noen rekkefølge. HashSet lagrer et Set ved å bruke hash-verdier. TreeSet lagrer et Set i et tre. Map lagrer par av nøkkel+verdi. HashMap lagrer en Map ved hjelp av hash-verdier. TreeMap lagrer en Map i et tre.
12 Dokumentasjon er uvurderlig! Dokumentasjon av Java-biblioteket overview-summary.html er en ypperlig dokumentasjon:
13 La oss lage våre egne lister La oss lage en liste Før vi starter programmeringen, må vi bestemme oss for hvilke operasjoner vi ønsker oss. Hva trenger vi i en lineær lagringsstruktur get henter et element fra en gitt posisjon. add utvider listen med et nytt element. set erstatter elementet i et gitt posisjon med et nytt. remove fjerner elementet i en gitt posisjon. size forteller hvor lang listen vår er nå.
14 La oss starte med grensesnittet Start med grensesnittet Vi bør alltid starte med å definere grensesnittet i form av et interface: Liste.java interface Liste { public abstract int size(); public abstract void add( x); public abstract void set(int pos, x); public abstract get(int pos); public abstract remove(int pos);
15 Men, hva skal vi lagre Problem: hva skal vi lagre Vi ønsker å lagre mange ulike objekter i listen vår. Hvordan kan vi angi det Løsning: Object-er I Java er klassen Object superklassen til alle klasser, enten direkte eller via andre klasser. Følgelig kan en Object-referanse peke på absolutt alle objekter.
16 En løsning med Object-er En mulig løsning: Liste.java interface Liste { public abstract int size(); public abstract void add(object x); public abstract void set(int pos, Object x); public abstract Object get(int pos); public abstract Object remove(int pos); En halvgod løsning u Den virker. Men... d Kronglete notasjon siden vi må typekonvertere: lx.set(10, ((String)lx.get(10))+"*");
17 Når metoder kan ha parametre, kan ikke klasser også Klasseparametre Vi ønsker å lage for eksempel lister av Lege-er lister av Resept-er lister av String-er Da hadde det vært fint om vi kunne ha Lege, Resept, String etc som parameter til Liste-ne våre, på samme må som verdier kan være parametre til metoder.
18 Et interface med parametre En løsning Java har klasseparametre (også kalt generiske klasser eller «generics»): Liste.java interface Liste<T> { public abstract int size(); public abstract void add(t x); public abstract void set(int pos, T x); public abstract T get(int pos); public abstract T remove(int pos);
19 La oss lagre referansene i en array En løsning med array Vi skal lagre referansene våre i en array: Type: T[] Navn: ibruk Type: int class Arrayliste Type: T[]
20 La oss lagre referansene i en array Så kan vi legge nye elementer inn i arrayen: Type: T[] Navn: ibruk Type: int class Arrayliste Type: T[]
21 Koden starter slik: Klassen Arrayliste Programkoden starter slik: Arrayliste.java class Arrayliste<T> implements Liste<T> { private T[] data = new T[10]; private int ibruk = 0; Men dette fungerer ikke! $ javac Arrayliste.java Arrayliste.java:3: error: generic array creation private T[] data = new T[10]; ^ 1 error
22 Java er ikke perfekt! En feil i Java! Denne feilen er egentlig en feil i Java selv! En løsning som fungerer Heldigvis finnes det en nødutvei: Arrayliste.java class Arrayliste<T> implements Liste<T> { private T[] data = (T[])new Object[10]; private int ibruk = 0; Den gir en advarsel, men fungerer ellers fint.
23 Da setter vi i gang Klassen Arrayliste Arrayliste.java class Arrayliste<T> implements Liste<T> { private T[] data = (T[])new Object[10]; private int ibruk = 0; Metoden set: public void set(int pos, T x) { data[pos] = x; Metoden get: public T get(int pos) { return data[pos];
24 Da setter vi i gang Metoden size: public int size() { return ibruk; Metoden remove: For å fjerne et element, må vi dytte elementene lenger opp i arrayen ett hakk ned. public T remove(int pos) { T res = data[pos]; for (int i = pos+1; i < ibruk; i++) data[i-1] = data[i]; ibruk--; return res;
25 Da setter vi i gang Metoden add: Det er enkelt å legge til et element i arrayen, med ett unntak: Hvis arrayen er full, må vi 1 opprette en ny array dobbelt så stor og 2 kopiere innholdet over dit. public void add(t x) { if (ibruk == data.length) { T[] ny = (T[])new Object[2*iBruk]; for (int i = 0; i < ibruk; i++) ny[i] = data[i]; data = ny; data[ibruk] = x; ibruk++;
26 Intet program er komplett uten testing! Testing TestListe.java estliste { public static void main(string[] args) { Liste<String> lx = new Arrayliste<>(); // Sett inn 13 elementer: for (int i = 0; i <= 12; i++) lx.add("a"+i); // Sjekk størrelsen: System.out.println("Listen har " + lx.size() + " elementer"); // Marker element nr 10: lx.set(10, lx.get(10)+"*"); // Fjern det første elementet: String s = lx.remove(0); System.out.println("Fjernet " + s); // Skriv ut innholdet: for (int i = 0; i < lx.size(); i++) System.out.println("Element " + i + ": " + lx.get(i)); // Lag en feil: lx.remove(999);
27 Intet program er komplett uten testing! Resultatet av testen er: java TestListe Listen har 13 elementer Fjernet A0 Element 0: A1 Element 1: A2 Element 2: A3 Element 3: A4 Element 4: A5 Element 5: A6 Element 6: A7 Element 7: A8 Element 8: A9 Element 9: A10* Element 10: A11 Element 11: A12 Exception in thread "main" java.lang.arrayindexoutofboundsexception: 999 at Arrayliste.remove(Arrayliste.java:30) at TestListe.main(TestListe.java:25) Det meste går bra, men 1 Gal parameter til remove gir en uforståelig feilmelding. (Det gjelder også get og set.)
28 Vi bør lage egne feilmeldinger Egne feilmeldinger En feilmeldinger bør være en subklasse av RuntimeException. Vi bør ta vare på relevant informasjon. UlovligListeindeks.java class UlovligListeindeks extends RuntimeException { public UlovligListeindeks(int pos, int max) { super("listeindeks " + pos + " ikke i intervallet 0-" + max); Da kan vi fange feilen og gi en god feilmelding: try { lx.remove(999); catch (UlovligListeindeks u) { System.out.println("Feil: "+u.getmessage());
29 Da er vi ferdige En perfekt(!) ArrayList Arrayliste.java class Arrayliste<T> implements Liste<T> { private T[] data = (T[])new Object[10]; private int ibruk = 0; public void set(int pos, T x) { if (pos<0 pos>=ibruk) throw new UlovligListeindeks(pos,iBruk-1); data[pos] = x; public T get(int pos) { if (pos<0 pos>=ibruk) throw new UlovligListeindeks(pos,iBruk-1); return data[pos]; public T remove(int pos) { if (pos<0 pos>=ibruk) throw new UlovligListeindeks(pos,iBruk-1); T res = data[pos]; for (int i = pos+1; i < ibruk; i++) data[i-1] = data[i]; ibruk--; return res;
30 Hvordan holde orden på mange objekter Hvordan holde orden på objekter class C class C class C class C class C class C class C Vi har mange objekter, men vi vet ikke på forhånd hvor mange. Hvordan holder vi orden på dem Vi må kunne class C finne frem til et gitt objekt (for eksempel nr 7) sette inn nye objekter fjerne objekter Finnes det andre muligheter enn å bruke en array
31 Vi kan kjede sammen pekerne til data Løsningen er lenkelister Navn: start Navn: neste Navn: neste Navn: neste null class Node { Node neste = null; T data; Type: T class Node Type: T class Node Type: T class Node Node(T x) { data = x; private Node start = null; 1 La hver Node inneholde en peker til det neste objektet. 2 Hver Node peker også på sine data. 3 Vi har en peker start til det første objektet.
32 Vi kan kjede sammen pekerne til data Klassen Lenkeliste Lenkeliste.java class Lenkeliste<T> implements Liste<T> { class Node { Node neste = null; T data; Node(T x) { data = x; private Node start = null; public int size() { public void add(t x) { public void set(int pos, T x) { public T get(int pos) { public T remove(int pos) {
33 Operasjonene til Liste Hvordan finne størrelsen Vi må gå gjennom listen og telle alle nodene: Navn: start Node p = start; int n = 0; Navn: neste Navn: neste Navn: neste while (p!= null) { n++; p = p.neste; null Hint: Type: T class Node Type: T class Node Type: T class Node Hvis man ofte skal finne lengden, er det lurt å ha lengden lagret i en egen variabel.
34 Operasjonene til Liste Hvordan hente et element Vi må telle oss frem til den riktige noden: Navn: start Navn: neste Navn: neste Navn: neste null Node p = start; for (int i = 0; i < pos; i++) p = p.neste; Type: T class Node Type: T class Node Type: T class Node
35 Operasjonene til Liste Hvordan sette et vilkårlig element i listen Vi må først telle oss frem til det aktuelle elementet i listen: Navn: start Navn: neste Navn: neste Navn: neste Node p = start; for (int i = 0; i < pos; i++) { p = p.neste; p.data = x; Type: T class Node Type: T class Node null Type: T class Node
36 Operasjonene til Liste Hvordan utvide listen med et element Vi må først telle oss frem til det siste elementet i listen: Navn: start Node p = start; while (p.neste!= null) p = p.neste; p.neste = new Node(x); Navn: neste Navn: neste Navn: neste null NB! Det er ett spesialtilfelle vi må kunne håndtere: Hvis listen er tom, hva må gjør vi da Type: T class Node Type: T class Node Type: T class Node
37 Operasjonene til Liste Hvordan fjerne et element fra listen Vi må først telle oss frem til elementet før det som skal fjernes: Navn: start Node p = start; for (int i = 1; i < pos; i++) p = p.neste; Node n = p.neste; p.neste = n.neste; Navn: neste Navn: neste Navn: neste null NB! Type: T class Node Type: T class Node Type: T class Node Igjen: Hva gjør vi for å fjerne det første elementet i listen
Array&ArrayList Lagring Liste Klasseparametre Arrayliste Testing Lenkelister Videre
Dagens tema Lister og generiske klasser, del I Array-er og ArrayList (Big Java 6.1 & 6.8) Ulike lagringsformer (Collection) i Java (Big Java 15.1) Klasser med typeparametre («generiske klasser») (Big Java
1- og 2-veis Innkapsling Java Stabel Kø Prio-kø Iterator. Enveis- og toveislister Innkapsling («boxing») (Big Java 6.8.5)
Dagens tema Litt mer om vanlige lister Enveis- og toveislister Innkapsling («boxing») (Big Java 6.8.5) Nyttige varianter av lister: Stabler («stacks») (Big Java 15.5.1) Køer («queues») (Big Java 15.5.2)
1- og 2-veis Innkapsling Java Stabel Kø Prio-kø Iterator. Enveis- og toveislister Innkapsling («boxing») (Big Java 6.8.5)
Dagens tema Litt mer om vanlige lister Enveis- og toveislister Innkapsling («boxing») (Big Java 6.8.5) Nyttige varianter av lister: Stabler («stacks») (Big Java 15.5.1) Køer («queues») (Big Java 15.5.2)
Oppsummering del 2. Læringsmål Viktigste Java-elementer Eksamen Til sist. Læringsmål Hovedpunkter Tilbakemelding Eksamen. IN1010 uke 17 våren 2019
Oppsummering del 2 Læringsmål Viktigste Java-elementer Eksamen Til sist Hva skal dere ha lært? Læringsmål fra emnebeskrivelsen: Etter å ha tatt IN1010: har du god oversikt over programmeringsspråket Java
IN1010 våren januar. Objektorientering i Java
IN1010 våren 2018 23. januar Objektorientering i Java Om enhetstesting Om arrayer og noen klasser som kan ta vare på objekter Stein Gjessing Hva er objektorientert programmering? F.eks: En sort boks som
Algoritmer og datastrukturer Kapittel 3 - Delkapittel 3.1
Delkapittel 3.1 Grensesnittet Liste Side 1 av 11 Algoritmer og datastrukturer Kapittel 3 - Delkapittel 3.1 3.1 En beholder 3.1.1 En beholder En pappeske er en beholder En beholder er noe vi kan legge ting
PG4200 Algoritmer og datastrukturer Forelesning 5 Implementasjon av lister
PG4200 Algoritmer og datastrukturer Forelesning 5 Implementasjon av lister Lars Sydnes, NITH 5. februar 2014 I. Implementasjoner Tabell-implementasjon av Stakk Tabellen er den lettest tilgjengelige datastrukturen
UNIVERSITETET I OSLO
UNIVERSITETET I OSLO Side 1 Det matematisk-naturvitenskapelige fakultet Eksamen i: INF1010 Objektorientert programmering Eksamensdag: Onsdag 4. juni 2014 Tid for eksamen: 9:00-15:00 Oppgavesettet er på
UNIVERSITETET I OSLO
UNIVERSITETET I OSLO Det matematisk-naturvitenskapelige fakultet Eksamen i: INF1010 Objektorientert programmering Dato: 9. juni 2016 Tid for eksamen: 09.00 15.00 (6 timer) Oppgavesettet er på 7 sider.
Hva er en liste? Hvert element har en forgjenger, unntatt første element i listen. Hvert element har en etterfølger, unntatt siste element i listen
Lister Hva er en liste? Listen er en lineær datastruktur Hvert element har en forgjenger, unntatt første element i listen Hvert element har en etterfølger, unntatt siste element i listen I motsetning til
Oppsummering. Kort gjennomgang av klasser etc ved å løse halvparten av eksamen Klasser. Datastrukturer. Interface Subklasser Klasseparametre
Oppsummering Kort gjennomgang av klasser etc ved å løse halvparten av eksamen 2012. Klasser Interface Subklasser Klasseparametre Datastrukturer Hva er problemet? Oppgaven Emballasjefabrikken Renpakk skal
Hva er en liste? Hvert element har en forgjenger, unntatt første element i listen. Hvert element har en etterfølger, unntatt siste element i listen
Lister Hva er en liste? Listen er en lineær datastruktur Hvert element har en forgjenger, unntatt første element i listen Hvert element har en etterfølger, unntatt siste element i listen I motsetning til
INF1010. Stein Michael Storleer (michael) Lenkelister
INF1010 Stein Michael Storleer (michael) Lenkelister Lenke Datastrukturen lenkeliste class { = null ; foran foran = new () ; class { = null ; foran foran = new () ; foran. = new () ; class { = null ; foran
Fra Python til Java, del 2
Fra Python til Java, del 2 Hvordan kjøre Java? På Ifis maskiner På egen maskin Et eksempel Array-er For-setninger Lesing og skriving Metoder Biblioteket Hva trenger vi egentlig? Å kjøre Java For å kunne
INF1010, 22. mai Prøveeksamen (Eksamen 12. juni 2012) Stein Gjessing Inst. for Informatikk Universitetet i Oslo
INF, 22. mai 23 Prøveeksamen 23 (Eksamen 2. juni 22) Stein Gjessing Inst. for Informatikk Universitetet i Oslo Oppgave a Tegn klassehierarkiet for de 9 produkttypene som er beskrevet over. Inkluder også
EKSAMEN I FAG TDT4100 Objekt-orientert programmering. Fredag 3. juni 2005 KL. 09.00 13.00
Side 1 av 6 NTNU Norges teknisk-naturvitenskapelige universitet BOKMÅL Fakultet for informasjonsteknologi, matematikk og elektroteknikk Institutt for datateknikk og informasjonsvitenskap EKSAMEN I FAG
INF Notater. Veronika Heimsbakk 10. juni 2012
INF1010 - Notater Veronika Heimsbakk [email protected] 10. juni 2012 1 Tilgangsnivåer 2 CompareTo Modifier Class Package Subclass World public Y Y Y Y protected Y Y Y N no modifier Y Y N N
Liste som abstrakt konsept/datatype
Lister Liste som abstrakt konsept/datatype Listen er en lineær struktur (men kan allikevel implementeres ikke-lineært bak kulissene ) Hvert element har en forgjenger, unntatt første element i listen Hvert
INF1010 våren 2019 Onsdag 30. januar. Mer om unntak i Java (med litt repetisjon av I/O først)
INF1010 våren 2019 Onsdag 30. januar Mer om unntak i Java (med litt repetisjon av I/O først) Stein Gjessing Lesing fra terminal og fil navn: mininn Bruk Scanner: Scanner mininn = new Scanner(); Type:
INF Innleveringsoppgave 6
INF1010 - Innleveringsoppgave 6 Frist: Onsdag 16. mars, 10:00 Maks 6 poeng Om obligatorisk oppgave 4, 6 og 7 i INF1010, våren 2016: "Leger og resepter" Du skal jobbe med en problemstilling omkring leger
Algoritmer og datastrukturer E Løkker i Java
Vedlegg E Løkker i Java Side 1 av 6 Algoritmer og datastrukturer E Løkker i Java E Løkker i Java E.1 For-løkker En for-løkke består av de fire delene initialisering, betingelse, oppdatering og kropp (eng:
Forkurs INF1010. Dag 3. Andreas Færøvig Olsen Eivind Storm Aarnæs
Forkurs INF1010 Dag 3 Andreas Færøvig Olsen ([email protected]) Eivind Storm Aarnæs ([email protected]) Institutt for Informatikk, 14. januar 2015 Forkurs INF1010 - dag 3 Strenger Fil-I/O Unntakshåndtering
UNIVERSITETET I OSLO
UNIVERSITETET I OSLO Det matematisk-naturvitenskapelige fakultet Eksamen i INF1010 Objektorientert programmering Dato: 9. juni 2016 Tid for eksamen: 09.00 15.00 (6 timer) Oppgavesettet er på 7 sider. Vedlegg:
NORGES INFORMASJONSTEKNOLOGISKE HØGSKOLE PG4200 Algoritmer og datastrukturer
Oppgavesettet består av 7 (syv) sider. NORGES INFORMASJONSTEKNOLOGISKE HØGSKOLE PG4200 Algoritmer og datastrukturer Tillatte hjelpemidler: Ingen Side av 7 Varighet: 3 timer Dato:.august 203 Fagansvarlig:
Eks 1: Binærtre Binærtretraversering Eks 2: Binærtre og stakk
Godkjent oblig 1? Les e-post til din UiO-adresse Svar på e-post fra lablærer Ingen godkjenning før avholdt møte med lablærer Godkjentlistene brukes ikke til å informere om status for obligene Ta vare på
Konstruktører. Bruk av konstruktører når vi opererer med "enkle" klasser er ganske ukomplisert. Når vi skriver. skjer følgende:
Konstruktører Bruk av konstruktører når vi opererer med "enkle" klasser er ganske ukomplisert. Når vi skriver Punkt p = new Punkt(3,4); class Punkt { skjer følgende: int x, y; 1. Det settes av plass i
Post-it spørsmål fra timen (Arv og subklasser)
Post-it spørsmål fra timen 30.01 (Arv og subklasser) Tegning Spørsmål: Skjønte ikke tegningene Hater tegningene. Lær meg å tegne. Mvh frustrert elev. Spørsmål: Datastruktur-tegning, og hvor mye detaljer
INF1010 LISTER. Listeelementer og listeoperasjoner. Foran. Bak
LISTER Vanligste datastruktur Mange implementasjonsmåter (objektkjeder, array...) Operasjoner på listen definerer forskjellige typer lister (LIFO, FIFO,...) På norsk bruker vi vanligvis ordet «liste» for
< T extends Comparable<T> > Indre klasser mm. «Det du bør ha hørt om før oblig 4»
< T extends Comparable > Indre klasser mm. «Det du bør ha hørt om før oblig 4» Strukturen i oblig 3 null null null null Personbeholder pl null null Person p "Adnan" [email protected] INF1010 21. februar
BOKMÅL Side 1 av 7. KONTINUASJONSEKSAMEN I FAG TDT4100 Objektorientert programmering / IT1104 Programmering, videregående kurs
BOKMÅL Side 1 av 7 NTNU Norges teknisk-naturvitenskapelige universitet Fakultet for informasjonsteknologi, matematikk og elektroteknikk Institutt for datateknikk og informasjonsvitenskap KONTINUASJONSEKSAMEN
Gjøre noe i hele treet = kalle på samme metode i alle objekten. Java datastruktur Klassestruktur
Godkjent oblig 1? Les e-post til din UiO-adresse Svar på e-post fra lablærer Ingen godkjenning før avholdt møte med lablærer Godkjentlistene brukes ikke til å informere om status for obligene Ta vare på
INF1010. grensesni-et Comparable<T> grensesni-et Iterable<T> rekursjon
INF1010 grensesni-et Comparable grensesni-et Iterable rekursjon Tenk på hvordan en for- løkke «går igjennom» alle objektene i en array Iterator miniterator Object next() Iterator miniterator = new
INF1010 siste begreper før oblig 2
INF1010 siste begreper før oblig 2 Sammenligning. Mer lenkede lister. Forskjellige listeimplementasjoner. Binære trær. Bittelitt om grensesnitt (interface). Dagens forelesning Flere temaer på grunn av
Hva er verdien til variabelen j etter at følgende kode er utført? int i, j; i = 5; j = 10; while ( i < j ) { i = i + 2; j = j - 1; }
Hva er verdien til variabelen j etter at følgende kode er utført? int i, j; i = 5; j = 10; while ( i < j ) { i = i + 2; j = j - 1; Hva skrives ut på skjermen når følgende kode utføres? int [] tallene =
INF januar 2015 Stein Michael Storleer (michael) Lenkelister
INF1010 29. januar 2015 Stein Michael Storleer (michael) Lenkelister Lenke + lister = lenkelister Vi starter med lenkeobjektene Lager en kjede av objekter ved hjelp av pekere class { ; Legger Jl data innholdet
Jentetreff INF1000 Debugging i Java
Jentetreff INF1000 Debugging i Java Ingrid Grønlie Guren [email protected] 11. november 2013 Kort om feilmeldinger i Java Java har to ulike type feilmeldinger som man kan få når man skriver
Kapittel 8: Programutvikling
Kapittel 8: Programutvikling Redigert av: Khalid Azim Mughal ([email protected]) Kilde: Java som første programmeringsspråk (3. utgave) Khalid Azim Mughal, Torill Hamre, Rolf W. Rasmussen Cappelen Akademisk
IN1010. Fra Python til Java. En introduksjon til programmeringsspråkenes verden Dag Langmyhr
IN1010 Fra Python til Java En introduksjon til programmeringsspråkenes verden [email protected] Oversikt Introduksjon Python Java Noe er likt Noe bare ser anderledes ut Noe er helt forskjellig Et par eksempler
INF1010, 21. februar Om å gå gjennom egne beholdere (iteratorer) Stein Gjessing Inst. for Informatikk Universitetet i Oslo
INF1010, 21. februar 2013 Om å gå gjennom egne beholdere (iteratorer) Stein Gjessing Inst. for Informatikk Universitetet i Oslo Ikke noe nytt her From the Java language specification (version 6): 14.14.2
Dagens tema. Hva er kompilering? Anta at vi lager dette lille programmet doble.rusc (kalt kildekoden): Hva er kompilering?
Dagens tema Dagens tema Kildekode Hva er kompilering? Hva er kompilering? Hvordan foreta syntaksanalyse av et program? Hvordan programmere dette i Java? Hvordan oppdage feil? Anta at vi lager dette lille
UNIVERSITETET I OSLO
FASIT UNIVERSITETET I OSLO BOKMÅL Det matematisk-naturvitenskapelige fakultet Kontinuasjonseksamen i : Eksamensdag : INF1000 Grunnkurs i objektorientert programmering Fredag 7. januar Tid for eksamen :
Lenkelister, iteratorer, indre klasser. Repetisjonskurs våren 2018 kristijb
Lenkelister, iteratorer, indre klasser Repetisjonskurs våren 2018 kristijb Lenket liste av objekter Vi lager en lenke ved at objekter refererer til hverandre. Vanlige er ofte å ha Node-objekter som har
Kompilering Statiske Syntaksanalyse Feilsjekking Eksempel Oppsummering
Dagens tema Hva er kompilering? Hvordan foreta syntaksanalyse av et program? Hvordan programmere dette i Java? Statiske metoder og variabler Hvordan oppdage feil? Kildekode Hva er kompilering? Anta at
Løsningsforslag Test 2
Løsningsforslag Test 2 Oppgave 1.1: Interface definerer et grensesnitt som kan implementeres av flere klasser. Dette gir en standardisert måte å kommunisere med objekter av en eller flere relaterte klasser.
TOD063 Datastrukturer og algoritmer
TOD063 Datastrukturer og algoritmer Øving : 3 Utlevert : Uke 7 Innleveringsfrist : 26. februar 2010 Klasse : 1 Data og 1 Informasjonsteknologi Gruppearbeid: 2-3 personer pr. gruppe. Oppgave 1 Vi skal lage
Rekursjon. (Big Java kapittel 13) Fra Urban dictionary: recursion see recursion. IN1010 uke 8 våren Dag Langmyhr
Fakultet Rekursjon Fibonacci Sjakk Hanois tårn Lister Oppsummering Rekursjon (Big Java kapittel 13) Fra Urban dictionary: recursion see recursion. n! = n x n-1 x n-2 x... x 2 x 1 Å beregne fakultet Den
Rekursjon. (Big Java kapittel 13) Fra Urban dictionary: recursion see recursion. IN1010 uke 8 våren Dag Langmyhr
Fakultet Bredde Rekursjon Fibonacci Sjakk Hanois tårn Lister Oppsummering Rekursjon (Big Java kapittel 13) Fra Urban dictionary: recursion see recursion. n! = n x n-1 x n-2 x... x 2 x 1 Å beregne fakultet
EKSAMEN. Algoritmer og datastrukturer. Eksamensoppgaven: Oppgavesettet består av 11 sider inklusiv vedlegg og denne forsiden.
EKSAMEN Emnekode: ITF20006 Emne: Algoritmer og datastrukturer Dato: Eksamenstid: 20. mai 2008 kl 09.00 til kl 13.00 Hjelpemidler: 4 A4-sider (2 ark) med valgfritt innhold Kalkulator Faglærer: Mari-Ann
Forkurs INF1010. Dag 2. Andreas Færøvig Olsen Gard Inge Rosvold Institutt for Informatikk, 14.
Forkurs INF1010 Dag 2 Andreas Færøvig Olsen ([email protected]) Gard Inge Rosvold ([email protected]) Institutt for Informatikk, 14. januar 2016 Forkurs INF1010 - dag 2 Feilmeldinger 2 Forkurs INF1010
23.09.2015. Introduksjon til objektorientert. programmering. Hva skjedde ~1967? Lokale (og globale) helter. Grunnkurs i objektorientert.
Grunnkurs i objektorientert programmering Introduksjon til objektorientert programmering INF1000 Høst 2015 Siri Moe Jensen INF1000 - Høst 2015 uke 5 1 Siri Moe Jensen INF1000 - Høst 2015 uke 5 2 Kristen
GUI («Graphical User Interface») del 2
GUI («Graphical User Interface») del 2 Interaksjon med brukeren Hendelsesdrevet programmering Tråder i GUI Et spill basert på klikkbare ruter Se også på Infoskrivet https://www.uio.no/studier/emner/matnat/
INF1010 våren januar. Objektorientering i Java
INF1010 våren 2017 25. januar Objektorientering i Java Om enhetstesting (Repetisjon av INF1000 og lær deg Java for INF1001 og INF1100) Stein Gjessing Hva er objektorientert programmering? F.eks: En sort
UNIVERSITETET I OSLO
UNIVERSITETET I OSLO BOKMÅL Det matematisk-naturvitenskapelige fakultet Kontinuasjonseksamen i : Eksamensdag : INF1000 Grunnkurs i objektorientert programmering Fredag 7. januar Tid for eksamen : 09.00
GUI («Graphical User Interface») del 2
GUI («Graphical User Interface») del 2 Interaksjon med brukeren Hendelsesdrevet programmering Tråder i GUI Se også på Infoskrivet https://www.uio.no/studier/emner/matnat/ ifi/in1010/v18/gui/fx-intro-in1010.pdf
Innhold. INF1000 Høst Unified Modeling Language (UML) Unified Modeling Language (UML)
Innhold Unified Modelling Language UML INF1000 Høst 2015 Uke 8: Mer objektorientert programmering Siri Moe Jensen En ny type for-løkke Organisering av mengder av objekter HashMap Valg av representasjon
UNIVERSITETET I OSLO
UNIVERSITETET I OSLO BOKMÅL Det matematisk-naturvitenskapelige fakultet Eksamen i : Eksamensdag : Torsdag 2. desember 2004 Tid for eksamen : 09.00 12.00 Oppgavesettet er på : Vedlegg : Tillatte hjelpemidler
Repitisjonskurs. Arv, Subklasser og Grensesnitt
Repitisjonskurs Arv, Subklasser og Grensesnitt Subklasser Klasser i OO-programmering representerer typer av objekter som deler et sett med egenskaper. En subklasse har egenskapene til en klasse + ett sett
Obligatorisk oppgave 4 i INF1010, våren 2014: "Leger og resepter" Versjon 1.1
Obligatorisk oppgave 4 i INF1010, våren 2014: "Leger og resepter" Versjon 1.1 Denne oppgaven skal løses to og to vha. systemutviklingsmetoden Parprogrammering. For å få levere må alle registrere seg gjennom
klassen Vin må få en ny variabel Vin neste alle personvariable (personpekere) i listeklassen må byttes til Vin
INF1010 forelesning Lenkelister II Dette skrivet inneholder en oversikt over det jeg planlegger å forelese på andre forlesning om lenkelister. Det inneholder stort sett programeksempler med kommentarer
2 Om statiske variable/konstanter og statiske metoder.
Litt om datastrukturer i Java Av Stein Gjessing, Institutt for informatikk, Universitetet i Oslo 1 Innledning Dette notatet beskriver noe av det som foregår i primærlageret når et Javaprogram utføres.
Dagens tema C, adresser og pekere
Dagens tema C, adresser og pekere (Kapittel 17 i Patt&Patel-boken) Variable og adresser Pekervariable Parametre Dynamisk allokering Stakker og ringbuffere Ark 1 av 26 Adresser Som nevnt tidligere ligger
INF1010, 15. januar 2014 2. time. Parametriserte klasser (generiske klasser) Stein Gjessing Inst. for Informatikk Universitetet i Oslo
INF1010, 15. januar 2014 2. time Parametriserte klasser (generiske klasser) Stein Gjessing Inst. for Informatikk Universitetet i Oslo Repetisjon fra gamle dager: Metoder med parametre En metode uten parameter:
INF1000 - Uke 10. Ukesoppgaver 10 24. oktober 2012
INF1000 - Uke 10 Ukesoppgaver 10 24. oktober 2012 Vanlige ukesoppgaver De første 4 oppgavene (Oppgave 1-4) handler om HashMap og bør absolutt gjøres før du starter på Oblig 4. Deretter er det en del repetisjonsoppgaver
Algoritmer og datastrukturer Kapittel 11 - Delkapittel 11.2
Algoritmer og datastrukturer Kapittel 11 - Delkapittel 11.2 11.2 Korteste vei i en graf 11.2.1 Dijkstras metode En graf er et system med noder og kanter mellom noder. Grafen kalles rettet Notasjon Verdien
Eksamen INF1010 V2009 Del B prøveeksamen V2010 Vekt 60 %
Eksamen INF1010 V2009 Del B prøveeksamen V2010 Vekt 60 % Stein Gjessing Institutt for Informatikk Universitetet i Oslo 1 Oppgave 10 Tegning av datastrukturen (vekt 5% av del B) Tegn datastrukturen til
Introduksjon til objektorientert programmering
Introduksjon til objektorientert programmering Samt litt mer om strenger og variable INF1000, uke6 Ragnhild Kobro Runde Grunnkurs i objektorientert programmering Strategi: Splitt og hersk Metoder kan brukes
INF Uke 10. Løsningsforslag ukesoppgaver oktober 2012
INF1000 - Uke 10 Løsningsforslag ukesoppgaver 10 24. oktober 2012 Løsningsforlag Oppgave 1 Array vs. HashMap a) Følgende program viser et enkelt banksystem med en array kontoer[], og metoder for å finne
UNIVERSITETET I OSLO
UNIVERSITETET I OSLO Det matematisk-naturvitenskapelige fakultet Eksamen i Eksamensdag: 12. desember 2008 Tid for eksamen: 9.00 12.00 Oppgavesettet er på 7 sider. Vedlegg: Tillatte hjelpemidler: INF2220
Leksjon 6. Objekt. Evt. importsetninger. public class Klasse { Konstruktør. Objektmetoder. Innkapsling (private): set-og get-metoder
6108 Programmering i Java Leksjon 6 Objekt Del 2: 6.4 6.5 Roy M. Istad 2015 Generelt oppsett av egendefinert klasse Eks: Student Evt. importsetninger public class Klasse { Objektvariabler - instansvariabler
INF våren 2017
INF1010 - våren 2017 Om Java Objekter og klasser Både for deg som kan og for deg som ikke kan Java Stein Gjessing Universitetet i Oslo Ny versjon etter forlesningen der tre meningsløse private modifikatorer
UNIVERSITETET I OSLO
UNIVERSITETET I OSLO Det matematisk-naturvitenskapelige fakultet Eksamen i Eksamensdag: 6. juni 2006 Tid for eksamen: 1430 1730 Oppgavesettet er på 6 sider. Vedlegg: INF1010 Objektorientert programmering
Enkle generiske klasser i Java
Enkle generiske klasser i Java Oslo, 7/1-13 Av Stein Gjessing, Institutt for informatikk, Universitetet i Oslo Del 1: Enkle pekere Før vi tar fatt på det som er nytt i dette notatet, skal vi repetere litt
Dagens forelesning. Husk prøveeksamen Fredag 15/3-13 kl 12 i R1. Iterator-teknikken. Eksempel med bruk av Iterator og Iterable-grensesnittene
Dagens forelesning Iterator-teknikken Hva er en Iterator og hvorfor bruke den? Hvordan virker en Iterator? Vi lager en Iterator for tegnene i en String Iterable-grensesnittet og for-løkker Eksempel med
Oppgave 1. Sekvenser (20%)
Det matematisk-naturvitenskapelige fakultet UNIVERSITETET I BERGEN Eksamen i emnet I 20 - Algoritmer, datastrukturer og programmering Mandag 2.Mai 200, kl. 09-5. Ingen hjelpemidler tillatt. Oppgavesettet
2 Om statiske variable/konstanter og statiske metoder.
Gaustadbekkdalen, januar 22 Litt om datastrukturer i Java Av Stein Gjessing, Institutt for informatikk, Universitetet i Oslo Innledning Dette notatet beskriver noe av det som foregår i primærlageret når
Gjennomgang av eksamen H99
Gjennomgang av eksamen H99 Administrasjon av kurser, studenter og påmeldinger Ole Christian Lingjærde Gruppen for bioinformatikk Institutt for Informatikk Universitetet i Oslo Oppgave 1 (15 %) (Besvares
Algoritmer og datastrukturer Løsningsforslag
Algoritmer og datastrukturer Løsningsforslag Eksamen 30. november 2010 Oppgave 1A Et turneringstre for en utslagsturnering med n deltagere blir et komplett binærtre med 2n 1 noder. I vårt tilfelle får
TDT4100 Objektorientert programmering
Eksamensoppgave i TDT4100 Objektorientert programmering Mandag 6. august 2012, kl. 15:00-19:00 Oppgaven er utarbeidet av faglærer Hallvard Trætteberg og kvalitetssikrer Rune Sætre. Kontaktperson under
Forelesning inf Java 5
Ole Chr. Lingjærde 1 Forelesning inf1000 - Java 5 Tema: Mer om metoder 2D-arrayer String Ole Christian Lingjærde, 26. september 2013 Ole Chr. Lingjærde Institutt for informatikk, 26. september 2013 1 Strukturen
La oss begynne med en repetisjon av hva som skjer når du kjører Javaprogrammet
K A P I T T E L 18 Tråder N år et program kjøres, utføres programsetningene i en bestemt rekkefølge. En tråd er det samme som denne programflyten, og i dette kapitlet skal vi se på hvordan vi starter og
