Föreläsning 3. Föreläsning 3

Storlek: px
Starta visningen från sidan:

Download "Föreläsning 3. Föreläsning 3"

Transkript

1 Datatypen De enkla datatyperna, som används för att lagra tal (t.ex. int och ), har en begränsad storlek och representerar således endast en delmängd av de verkliga talen. Föreläsning 3 Detta innebär att ett resultat eller ett mellanresultat från en beräkning av ett uttryck kan bli ett värde som inte kan lagras. Iteration -satsen for-satsen do-satsen Resulterar uttrycket i ett för stort värde uppstår overflow och om uttrycket resulterar i ett för litet värde uppstår underflow. underflow Föreläsning 3 Iteration Datatypen Exempel: Antag att vi lagrar decimala tal med 4 decimaler. Uttrycket 1.0/ / /3.0 kommer då att evalueras på följande sätt: -satsen for-satsen do-satsen När man handhar reella tal skall man 1.0/ / /3.0jämföra = aldrig på exakthet, utan istället = jämföra på tillräcklig noggrannhet. resultatet blir inte 1.0, som man kanske trott! Konsekvens: När man handhar reella tal skall man aldrig jämföra på exakthet, utan istället jämföra på tillräcklig noggrannhet. Reella tal lagras med ett bestämt antal signifikanta siffror, vilket innebär att det vid beräkningar uppstår trunkeringsfel och kancellationsfel. kancellationsfel I en triangel kan man beteckna sidorna a, b och c. Om man känner till längden av sidorna a och b samt vinkeln mellan dessa sidor, kan man räkna ut längden av sidan c med hjälp av formeln: c= a 2 b2 2ab cos Skriv ett program som läser in längderna på två sidor i en triangel och vinkeln mellan dessa sidor (uttryckt i grader). Programmet skall avgöra om triangeln är liksidig (alla sidor lika långa), likbent (två sidor lika långa) eller oliksidig (inga sidor är lika långa). Programmet skall ge lämpliga utskrifter.

2 Indata: Längderna A och B på två sidor i triangeln, samt den mellanliggande vinkeln VG i grader. Utdata: Utskrift av huruvida triangeln är liksidig, likbent eller oliksidig. 1. Läs längderna på sidorna A och B, samt gradtalet VG av den mellanliggande vinkeln. 2. Beräkna VR som den mellanliggande vinkeln uttryckt i radianer. 3. Beräkna längden C av den den okända sidan i triangeln med hjälp av formeln C= A B 2AB cos VR vinkel, /* Programmet läser in längderna av två sidor i en triangel samt mellanliggande 4. Om A - B */ och A - C och B - C så * och huruvidatriangeln är liksidig, likbent eller oliksidig. I klassen Math iskriver Java anges ut parametrarna till de trigonometriska skriv ut att triangeln är liksidig Varför måste vi funktionerna i radianer. Därför är en omvandling av vinkeln från grader till import javax.swing.joptionpane; göra jämförn annars om A - B eller A - C eller B - C så radianer nödvändig att göra. B C skriv ut att triangeln är likbent import java.util.scanner; Denna omvandling kan antingen göras genom att använda metoden annars class Triangle toradians i klassen Math, eller genom att använda formeln skriv ut att triangeln är oliksidig. VR = VG /180static void main( [] arg) Datarepresentation: Längderna A, B och C samt vinklarna VG och VR är av datatypen. där VR är vinkeln i radianer och = VG0.001; är vinkeln uttryckt i grader. finaluttryckt EPS Konstanten PI, för att avbilda finns tillgänglig i klassen Math. För att två sidor skall betraktas lika antas att sidornas längder skiljer som = JOptionPane.showInputDialog("Ange längden två samt" Klassenav Math har ensidor klassmetod toradians för att omvandla från grader till radianer. sig med mindre än längdenheter. Konstanten EPS = 0.001, för att avbilda. + " mellanliggande vinkel: "); Scanner sc = new Scanner(); a = sc.nextdouble(); b = sc.nextdouble(); anglegrades = sc.nextdouble(); angleradians = Math.toRadians(angleGrades); Styrstrukturerna i Java c = Math.sqrt(a*a + b*b - 2.0*a*b*Math.cos(angleRadians)); /* Programmet läser in längderna av två sidor i en triangel samt mellanliggande vinkel, * och skriver ut huruvidatriangeln är liksidig, likbent oliksidig. */ && (Math.abs(a - c) <= EPS) && (Math.abs(b - c) <= EPS)) if ((Math.abs(a - b)eller<= EPS) tilldelningssatsen "LIKSIDIG"); Sekvens: class Triangle selektionssatser static void main(if [] arg) ((Math.abs(a -b) <= EPS) (Math.abs(a - c) <= EPS) (Math.abs(b - c) <= EPS)) final EPS = 0.001; iterationssatser = JOptionPane.showInputDialog("Ange längden av två sidor samt" "LIKBENT"); return-satsen + " mellanliggande vinkel: "); Scanner sc = new Scanner(); anrop av void-metod a = sc.nextdouble(); programblock b = sc.nextdouble(); "OLIKSIDIG"); anglegrades = sc.nextdouble(); exception angleradians //main= Math.toRadians(angleGrades); c = Math.sqrt(a*a + b*b - 2.0*a*b*Math.cos(angleRadians)); Selektion: if-satsen if ((Math.abs(a - b) <= EPS) && (Math.abs(a - c) <= EPS) && (Math.abs(b - c) <= EPS)) //Triangle "LIKSIDIG"); switch-satsen 2 2 Diskussion: if ((Math.abs(a -b) <= EPS) (Math.abs(a - c) <= EPS) (Math.abs(b - c) <= EPS)) "LIKBENT"); "OLIKSIDIG"); //main //Triangle Iteration: -satsen do-satsen for-satsen

3 Olika typer av iteration a) tills ett visst villkor blivit uppfyllt ( villkorsloop) villkorsloop b) ett på förhand bestämt antal gånger ( räkneloop) räkneloop Iteration: -satsen Upprepning av en sats: evaluera villkor false (villkor) true class Question Upprepning av ett Satser som kör om villkoret är sant Exempel: programblock: static void main( [] arg) a) Rör om tills smöret har smält (villkorsloop). (villkor) Scanner sc = new Scanner(System.in); sats1; b) Gå fem steg framåt (räkneloop) boolean done = false; Satser som kör efter -satsen satsn; (!done) System.out.print("Which language do we learn? "); answer = sc.next(); if (answer.equals("java")) done = true; Vad gör programmet? System.out.println("Nope, try again!"); class Question Antalet bakterier y i en bakterieodling efter t tidsenheter ges av static void main( [] arg) System.out.println("Well done!"); Scanner sc = new Scanner(System.in); formeln boolean done = false; //main (!done) y = y e1.386t System.out.print("Which language do we learn? "); //Question answer = sc.next(); n n if (answer.equals("java")) done = true; System.out.println("Nope, try again!"); System.out.println("Well done!"); //main //Question s där ys är antalet bakterier vid t = 0. Skriv ett program som beräknar hur många tidsenheter det tar innan en bakterieodling som innehåller en bakterie innehåller minst 1 miljard bakterier.

4 Indata: Ingen Utdata: Hur lång tid det tar innan bakterieodlingen innehåller minst 1 miljard bakterier. 1. Sätt tillväxttiden tid till Sätt ystart, antalet bakterier vid tiden 0, till Sätt totala antalet bakterier i odlingen ytotal till ystart. 4. Upprepa så länge som ytotal är mindre än Öka tid med Beräkna ytotal mha formeln ytotal = ystart * e1.386*tid class Bacteria static void main( [] arg) int time = 0; ystart = 1; ytotal = ystart; (ytotal < 1.0e9) time = time + 1; ytotal = ystart*math.exp(1.386*time); "Det tar " + time + " tidsenheter innan" + " odlingen innehåller 1 miljard bakterier."); //main //Bacteria class Bacteria static void main( [] arg) int time = 0; ystart = 1; 5. Skriv ut värdet av tid. Datarepresentation: ytotal = ystart; tid är av datatypen int. (ytotal < 1.0e9) ystart och ytotal är reella tal, dvs av datatypen. time = time + 1; ytotal = ystart*math.exp(1.386*time); "Det tar " + time + " tidsenheter innan" + " odlingen innehåller 1 miljard bakterier."); for-satsen Iteration: for-satsen //main //Bacteria Upprepning av en sats: initiering for (initiering; villkor; ändring) for (int i = 1; i <= 5; i = i + 1) System.out.println(i); false evaluera villkor Upprepning av ett programblock: true Satser som kör om villkoret är sant for (initiering; villkor; ändring) sats1; satsn; ändring Satser som kör efter for-satsen for-satsen är en villkorsloop, men använd for-satsen endast vid räkneloopar!!! for (char c = d ; c >= a ; c = (char) (c - 1)) System.out.println(c); for ( x = 0.5; x < 0.8; x = x + 0.1) System.out.println(x); Troligen inte förväntat resultat! Den styrande variabeln i en for-sats bör vara en uppräkningsbar datatyp. Ger utskriften: Ger utskriften: d c b a Ger utskriften:

5 Att omvandla en temperatur angiven i grader Fahrenheit till grader Celsius sker med följande formel: C = (F -32) 5 / 9, där C anger grader Celsius och F grader Fahrenheit Skriv ett program som skriver ut en omvandlingstabell från grader Fahrenheit till grader Celsius i intervallet från till grader Fahrenheit, där var grad anges. Fahrenheit Celsius class FahrenheitToCelsius Skriv ett program som läser in två heltal, som representerar antal rader static void main([] arg) respektive antal kolumner, och skriver ut nedanstående mönster i kommandofönstret: System.out.printf("%15s%12s", "Fahrenheit", Indata: Ingen Utdata: En konverteringstabell från grader Fahrenheit till grader Celcius som anger varje grad i intervallet till Skriv ut rubriken 2. För f = till 10.0 stega c = (f -32)*5/ Skriv ut f och c Datarepresentation: f är av datatypen int och c är av datatypen. class FahrenheitToCelsius static void main([] arg) System.out.printf("%15s%12s", "Fahrenheit", "Celsius\n"); for (int fahrenheit = -10; fahrenheit <= 10; fahrenheit = fahrenheit + 1) celsius = (fahrenheit -32) * 5.0 / 9.0; System.out.printf("%12.1f%13.1f\n", ( ) fahrenheit, celsius); //main //FahrenheitToCelsius import javax.swing.*; import java.util.*; class WriteStars static void main([] args) = JOptionPane.showInputDialog("Ange antal rader och antal kolumner: "); Scanner sc = new Scanner(); int nrofrows = sc.nextint(); int nrofcolumns = sc.nextint(); for (int row = 1; row <= nrofrows; row = row +1) for (int col = 1; col <= nrofcolumns; col = col +1) System.out.print("*"); System.out.println(); //main //WriteStars "Celsius\n"); for (int fahrenheit = -10; fahrenheit <= 10; fahrenheit = fahrenheit + 1) ********** ********** ********** antalcelsius rader = (fahrenheit -32) * 5.0 / 9.0; ********** **********System.out.printf("%12.1f%13.1f\n", () fahrenheit, celsius); antal kolumner //main //FahrenheitToCelsius 1. Läs antal rader r och antal kolumner k 2. För varje rad 2.1. För varje kolumn Skriv ut tecknet '*' 2.2. Skriv ut radslut

6 Iteration: do-satsen Exempel: Inläsningskontroll I en -satsen beräknas testuttrycket inför varje varv i loopen. I en do-satsen beräknas testuttrycket efter varje varv i loopen. En do-sats genomlöps minst en gång, medan en -sats kan genomlöpas noll gånger class InspectInput static void main ([] arg) int number; do = JOptionPane.showInputDialog("Ange ett tal mellan 1 och 200:"); number = Integer.parseInt(); if (number < 1 number > 200) "Ogiltigt tal! Försök igen!"); (number <1 number > 200); "Det accepterade talet är " + number); //main //InspectInput Upprepning class InspectInput av en sats: Satser som kör i static void main ([] arg) do do--satsen int number; (villkor); true do evaluera Upprepning av ett villkor = JOptionPane.showInputDialog("Ange ett tal mellan 1 och 200:"); programblock: do false static void main ([] arg) satser number = Integer.parseInt(); Satser som (villkor); kör efter intdo--satsen number; if (number < 1 number > 200) "Ogiltigt tal! Försök igen!"); (number <1 number > 200); "Det accepterade talet är " + number); //main //InspectInput Variablers räckvidd (scope) Evighetsloop och satsen break En variabels räckvidd är det kodavsnitt inom vilket variabeln går att använda. Konstruktionen (true) satser En variabel är synlig endast inom det programblock där "Det accepterade talet är " + number); variabeln deklarerats. //main number och innebär en evighetsloop. evighetsloop Grundprincip: static void main ([] arg) int number; kända här! do = JOptionPane.showInputDialog("Ange ett tal mellan 1 och 200:"); number = Integer.parseInt(); if (number < 1 number > 200) "Ogiltigt tal! Försök igen!"); (number <1 number > 200); "Det accepterade talet är " + number); //main okänd här! En variabels räckvidd skall begränsas så mycket som möjligt. En evighetsloop uppkommer vanligtvis på grund av ett misstag hos programmeraren, men kan ibland vara avsiktlig. En loop kan när som helst lämnas med hjälp av satsen break: Att lämna en loop via en break-sats, skall användas mycket restriktivt!!! (villkor) if (villkor för att sluta) break; Varför??? Observera att vid nästlade loopar lämnas den loop i vilken break-satsen står! (villkor) (villkor) if (villkor för att sluta) break;

7 Upprepad programkörning Upprepad programkörning Ett vanligt sätt att åstadkomma upprepad programkörning är en evighetsloop som avbryts via en class RepeatedExecution break-sats. static void main ([] arg) (true) = JOptionPane.showInputDialog("Ange cylinderns radie och höjd:"); if ( == null) break; Cancel-knappen Scanner sc = new Scanner(); returnerar null radius = sc.nextdouble(); height = sc.nextdouble(); volume = Math.PI * Math.pow(radius, 2) * height; output =.format("%s %.2f", "Volymen av cylindern är", volume); output); // //main //RepeatedExecution Tydligare än att använda en evighetsloop, som avbryts med break!! class RepeatedExecution static void main ([] arg) boolean done = false; (!done) = JOptionPane.showInputDialog("Ange cylinderns radie och höjd:"); if ( == null) done = true; Scanner sc = new Scanner(); radius = sc.nextdouble(); height = sc.nextdouble(); volume = Math.PI * Math.pow(radius, 2) * height; output =.format("%s %.2f", "Volymen av cylindern är", volume); output); // //main //RepeatedExecution Tydligare Ett vanligtän sätt attatt använda åstadkomma en upprepad programkörning evighetsloop, som avbryts med är en evighetsloop som avbryts via en break!! break-sats. class RepeatedExecution static void main ([] arg) (true) boolean done = false; (!done) = JOptionPane.showInputDialog("Ange cylinderns radie och höjd:"); if ( == null) = JOptionPane.showInputDialog("Ange cylinderns radie och höjd:"); if ( break;== null) Scanner done =sctrue; = new Scanner(); radius = sc.nextdouble(); Scanner height sc ==new sc.nextdouble(); Scanner(); volume radius= =Math.PI sc.nextdouble(); * Math.pow(radius, 2) * height; output height.format("%s = sc.nextdouble();%.2f", "Volymen av cylindern är", volume); for-, eller= do-satsen? volume = Math.PI * Math.pow(radius, output); 2) * height; -satsen är mest generella iterationssatsen, eftersom for- och do-satsen enkelt program som läser en indataserie bestående av N positiva heltal samt // output =.format("%s %.2f", "VolymenSkriv avettcylindern är", volume); kan simuleras med en -sats. beräknar och skriver ut medelvärdet av dessa tal. //main output); for (initiering; villkor; ändring) Räkneloop do //RepeatedExecution Indata: Antalet tal i dataserien samt själva dataserien. (villkor); // Utdata: Medelvärdet av talen i dataserien. initiering; Speciella åtgärder: Om inga tal ingår i dataserien kan inte medelvärdet beräknas. //main (villor) //RepeatedExecution (villor) ändring; Utkast till algoritm: 1. Läs in antalet heltal som ingår i dataserien till variabeln antal. använd for-satsen vid räkneloopar använd do-satsen om loopen skall gå minst ett varv använd -satsen i alla övriga fall är du osäker på vilken iterationssats som skall väljas, välj -satsen 2. Läs talen och beräkna talens sammanlagda summa i variabeln summa. 3. Beräkna medelvärdet medel mha formeln medel = summa / antal. 4. Skriv ut medelvärdet, dvs värdet av variabeln medel.

8 Mer detaljerad algoritm: 1. Läs in antalet heltal som ingår i dataserien till variabeln antal. 2. Sätt summa till Upprepa antal gånger 3.1. Läs ett tal till variabeln tal Addera summa och tal och spara resultatet i summa. Med användning av en for-sats class AddValues static void main([] arg) = JOptionPane.showInputDialog("Ange antalet tal i serien:"); int number = Integer.parseInt(); for (int i = 1; i <= number; i = i + 1) = JOptionPane.showInputDialog("Ange tal nr " + i + ": "); int value = Integer.parseInt(); sum = sum + value; if (number > 0) mean = () sum / () number; "Medelvärdet av talen är "+ mean); "Inga tal ingick i serien!"); //main //AddValues import javax.swing.joptionpane; class AddValues2 class AddValues void main([] arg) 4. Om antal > 0 så static 4.1. Beräkna medelvärdet medel mha formeln static void main([] arg) = JOptionPane.showInputDialog("Ange antalet tal i serien:"); medel = summa / antal ==Integer.parseInt(); JOptionPane.showInputDialog("Ange antalet tal i serien:"); int number 4.2. Skriv ut medelvärdet medel int number sum = 0;= Integer.parseInt(); annars int sum = 0; i = i0; 4.3. Skriv ut att inga värden ingick dataserien. for (int(i i<=number) 1; i <= number; i = i + 1) Datarepresentation: antal, summa och tal är heltal i av = typen i +=int. 1;JOptionPane.showInputDialog("Ange tal nr " + i + ": "); int value = Integer.parseInt(); medel är ett reellt tal av typen. = JOptionPane.showInputDialog("Ange tal nr " + i + ": "); sumvalue = sum + value; int = Integer.parseInt(); sum = sum + value; if (number > 0) mean if (number > 0) = () sum / () number; Med användning av en -sats av talen är "+ mean); mean = () sum / () "Medelvärdet number; class AddValues2 "Medelvärdet av talen är "+ mean); static void main([] arg) = JOptionPane.showInputDialog("Ange antalet tal i serien:"); Skriv ett program som läsa och beräkna medelvärdet av ett okänt antal int number = Integer.parseInt(); "Inga tal ingick i serien!"); positiva heltal. Serien av heltalen avslutas med ett negativt heltal int i = 0; "Inga tal (vilket inte ingår i serien). ingick i serien!"); (i < number) i = i + 1; //main = JOptionPane.showInputDialog("Ange tal nr " + i + ": "); int value = Integer.parseInt(); //AddValues sum = sum +//main value; Indata:Talen i dataserien som skall läsas in, samt ett negativt tal som if (number//addvalues2 > 0) mean = () sum / () number; "Medelvärdet av talen är "+ mean); "Inga tal ingick i serien!"); //main //AddValues2 avbryter inläsningen. Utdata: Medelvärdet av talen som ingår i dataserien. Speciella åtgärder: Om inga tal ingår i dataserien kan inte medelvärdet beräknas.

9 1. Sätt summa till 0 och antal till Läs ett tal till variabeln tal. 3. Upprepa så länge som tal Öka antal med Addera summa och tal och spara resultatet i summa Läs ett tal till variabeln tal. 4. Om antal > 0 så 4.1. Beräkna medelvärdet medel mha formeln medel = summa/antal 4.2. Skriv ut medelvärdet medel annars 4.3. Skriv ut att inga värden ingick i dataserien. class AddValues3 static void main([] arg) int number = 0; = JOptionPane.showInputDialog("Ange tal nr " + (number+1) + ":"); int value = Integer.parseInt(); duplicerad (value > 0) kod number = number + 1; sum = sum + value; = JOptionPane.showInputDialog("Ange tal nr " + (number + 1) + ": "); value = Integer.parseInt(); if (number > 0) mean = () sum / () number; "Medelvärdet av talen är "+ mean); "Inga tal ingick i serien!"); //main //AddValues3 class AddValues3 static void main([] arg) int number = 0; = JOptionPane.showInputDialog("Ange tal nr " + (number+1) + ":"); int value = Integer.parseInt(); Datarepresentation: antal, summa och tal är heltal av typen (value > int. 0) number = number + 1; sum = sum + value; = JOptionPane.showInputDialog("Ange tal nr " + (number + 1) + ": "); value = Integer.parseInt(); if (number > 0) mean = () sum / () number; 1. Sätt summa till 0 och antal till 0. Skriv ett program som läsa och beräkna medelvärdet av ett okänt antal heltal. Upprepa "Medelvärdet2.av talen är "+ mean); 2.1. Gör en inläsning från dialogfönstret till variabeln indata Om indata == null gå till punkt Öka antal med 1. Diskussion: Nu kan alla heltal ingå i dataserien och hur skall vi då kunna Konvertera indata till heltalet tal. "Inga tal ingick 2.4. i serien!"); markera slutet på serien? Ett sätt är att utnyttja Cancel2.5. Addera summa och tal och spara resultatet i summa. knappen i dialogrutan. När man trycker på Cancel returneras 3. Om antal > 0 så värdet null Beräkna medelvärdet medel med hjälp av formeln //main medel = summa/antal Indata: Talen i dataserien som skall läsas in. Inläsningen avbryts genom att //AddValues Skriv ut medelvärdet medel trycka på Cancel-knappen i dialogrutan. Utdata: Medelvärdet av talen som ingår i dataserien. Speciella åtgärder: Om inga tal ingår i dataserien kan inte medelvärdet beräknas. annars 3.3. Skriv ut att inga värden ingick i dataserien. Datarepresentation: antal, summa och tal är heltal av typen int. medel är ett reellt tal av typen.

10 class AddValues4 static void main( [] arg) int number = 0; boolean done = false; (!done) = JOptionPane.showInputDialog("Ange nästa tal i serien\n" + "Avsluta ned Cancel"); if ( == null) done = true; int value = Integer.parseInt(); number = number + 1; sum = sum + value; if (number > 0) mean = () sum / () number; "Medelvärdet av talen är "+ mean); "Inga tal ingick i serien!"); //main //AddValues4 class AddValues5 static void main( [] arg) int number = 0; boolean done = false; (!done) = JOptionPane.showInputDialog("Ange talen. Avsluta med Cancel!"); if ( == null) done = true; Scanner sc = new Scanner(); (sc.hasnext()) int value = sc.nextint(); number = number + 1; sum = sum + value; if (number > 0) mean = () sum / () number; "Medelvärdet av talen är "+ mean); "Inga tal ingick i serien!"); //main //AddValues5 importjava.util.scanner; javax.swing.joptionpane; import class class AddValues4 AddValues5 static void main( [] static void main( [] arg) arg) intint number = 0;= 0; number intint sumsum = 0;= 0; boolean done = false; boolean done = false; (!done) (!done) = JOptionPane.showInputDialog("Ange talen. Avsluta med Cancel!"); = JOptionPane.showInputDialog("Ange nästa tal i serien\n" + if ( == null) "Avsluta ned Cancel"); done = true; if ( == null) done sc = true; Scanner = new Scanner(); (sc.hasnext()) intvalue value==sc.nextint(); Integer.parseInt(); int number==number number+ + number 1; 1; sum==sum sum+ +value; value; sum if (number > 0) if (number 0) = () sum / () number; > mean mean = () sum / () number; "Medelvärdet av talen är "+ mean); "Medelvärdet av talen är "+ mean); "Inga tal ingick i serien!"); "Inga tal ingick i serien!"); //main //main //AddValues4 //AddValues5

Föreläsning 3. Föreläsning 3

Föreläsning 3. Föreläsning 3 Datatypen De enkla datatyperna, som används för att lagra tal (t.ex. int och ), har en begränsad storlek och representerar således endast en delmängd av de verkliga talen. Föreläsning 3 Detta innebär att

Läs mer

Föreläsning 3. Iteration. while-satsen for-satsen do-satsen

Föreläsning 3. Iteration. while-satsen for-satsen do-satsen Föreläsning 3 Iteration while-satsen for-satsen do-satsen Datatypen double De enkla datatyperna, som används för att lagra tal (t.ex. int och double), har en begränsad storlek och representerar således

Läs mer

Föreläsning 3. Iteration while-satsen

Föreläsning 3. Iteration while-satsen Föreläsning 3 Iteration while-satsen Datatypen double I en dator kan man inte lagra hur stora eller hur små tal som helst. De enkla datatyperna, som används för att lagra tal (t.ex. int och double), har

Läs mer

Iteration. Föreläsning 3. TDA540 - Objektorienterad Programmering

Iteration. Föreläsning 3. TDA540 - Objektorienterad Programmering Iteration Föreläsning 3 TDA540 - Objektorienterad Programmering Meddelande Kursrepresentanter: - Mattias Ajander, Daniel Hultgren, Sanna Sandberg - Mejladresserna finns på kurshemsidan Jätte välkommen

Läs mer

Föreläsning 3. Föreläsning 3. Iteration. while-satsen for-satsen do-satsen. while-satsen. do-satsen. Datatypen double

Föreläsning 3. Föreläsning 3. Iteration. while-satsen for-satsen do-satsen. while-satsen. do-satsen. Datatypen double Föreläsning 3 Föreläsning 3 Iteration while-satsen for-satseniteration do-satsen while-satsen for-satsen do-satsen Datatypen double De enkla datatyperna, som används för att lagra tal (t.ex. int och double),

Läs mer

Objektorienterad programmering

Objektorienterad programmering Objektorienterad programmering Iteration: while-satsen, for-satsen och do-satsen Dr. Alex Gerdes Dr. Carlo A. Furia Hösttermin 2016 Chalmers University of Technology Meddelande Studentrepresentanter Reflektera

Läs mer

Iteration while-satsen

Iteration while-satsen Datatypen double TDA143 I1 Programmerade system Föreläsning 3 (OH-bilder 3) Iteration while-satsen Christer Carlsson I en dator kan man inte lagra hur stora eller hur små tal som helst. De enkla datatyperna,

Läs mer

Föreläsning 7. for-satsen Fält

Föreläsning 7. for-satsen Fält Föreläsning 7 for-satsen Fält for-satsen for-sats är en styrsats för iterationer. for-sats har följande generella utseende: for (initiering; villkor; ändring) sats; for-satsen är ekvivalent med följande

Läs mer

Lösningsförslag: Instuderingsfrågor, del A

Lösningsförslag: Instuderingsfrågor, del A Uppgift 1. Objektorienterad programmering, Z1 Lösningsförslag: Instuderingsfrågor, del A Följande regler gäller för namngivning av identifierare i Java: 1. Ett identifierarnamn består endast av bokstäver,

Läs mer

JAVAUTVECKLING LEKTION 4

JAVAUTVECKLING LEKTION 4 JAVAUTVECKLING LEKTION 4 2016 Mahmud Al Hakim mahmud.al.hakim@nackademin.se www.alhakim.se AGENDA Iterationer (loopar) Algoritmer Mer om felsökning 1 WHILE-SATSEN String s = JOptionPane.showInputDialog("Talet

Läs mer

for-satsen Fält for-satsen Föreläsning 8 (OH-bilder 7) for-satsen for-sats är en styrsats för iterationer. for-sats har följande generella utseende:

for-satsen Fält for-satsen Föreläsning 8 (OH-bilder 7) for-satsen for-sats är en styrsats för iterationer. for-sats har följande generella utseende: for-satsen for-sats är en styrsats för iterationer. for-sats har följande generella utseende: TDA143 I1 Programmerade system Föreläsning 8 (OH-bilder 7) for-satsen for ( initiering; villkor; ändring) sats;

Läs mer

OOP Objekt-orienterad programmering

OOP Objekt-orienterad programmering OOP F2:1 OOP Objekt-orienterad programmering Föreläsning 2 Input/Output Programsatser Selektion Output OOP F2:2 Görs via System.out, anropa antingen print eller println: System.out.print("Hej"); System.out.println(

Läs mer

Föreläsning 2. Föreläsning 2. Primitiva datatyper Selektering. Primitiva datatyper Selektering. Operationer på datatypen double

Föreläsning 2. Föreläsning 2. Primitiva datatyper Selektering. Primitiva datatyper Selektering. Operationer på datatypen double Föreläsning 2 Primitiva datatyper Selektering Föreläsning 2 Primitiva datatyper Selektering Operationer på datatypen double Notation Betydelse Resultatets datatyp a + b addition double a - b subtraktion

Läs mer

Primitiva datatyper Selektering

Primitiva datatyper Selektering Hit kom vi förra föreläsningen TDA143 I1 Programmerade system Föreläsning 2 (OH-bilder 2) Primitiva datatyper Selektering /* Programmet läser in och adderar två heltal, */ /* samt skriver ut resultatet

Läs mer

Föreläsning 2. Primitiva datatyper Selektering

Föreläsning 2. Primitiva datatyper Selektering Föreläsning 2 Primitiva datatyper Selektering Hit kom vi förra föreläsningen /* Programmet läser in och adderar två heltal, samt skriver ut resultatet. */ import javax.swing.*; public class Addera { public

Läs mer

Kompilering och exekvering. Föreläsning 1 Objektorienterad programmering DD1332. En kompilerbar och körbar java-kod. Kompilering och exekvering

Kompilering och exekvering. Föreläsning 1 Objektorienterad programmering DD1332. En kompilerbar och körbar java-kod. Kompilering och exekvering Föreläsning 1 Objektorienterad programmering DD1332 Introduktion till Java Kompilering, exekvering, variabler, styrstrukturer Kompilering och exekvering Ett program måste översättas till datorns språk

Läs mer

Föreläsning 3-4 Innehåll

Föreläsning 3-4 Innehåll Föreläsning 3-4 Innehåll Skriva egna metoder Logiska uttryck Algoritm för att beräkna min och max Vektorer Datavetenskap (LTH) Föreläsning 3-4 HT 2017 1 / 36 Diskutera Vad gör programmet programmet? Föreslå

Läs mer

Tentamen OOP 2015-03-14

Tentamen OOP 2015-03-14 Tentamen OOP 2015-03-14 Anvisningar Fråga 1 och 2 besvaras på det särskilt utdelade formuläret. Du får gärna skriva på bägge sidorna av svarsbladen, men påbörja varje uppgift på ett nytt blad. Vid inlämning

Läs mer

Primitiva datatyper och selektering

Primitiva datatyper och selektering Primitiva datatyper och selektering Föreläsning 2 TDA540 - Objektorienterad Programmering Extra föreläsning imorgon! HC4 15:15-17:00 Sammanfattning föreläsning 1 Vad är en dator? Vad är ett program? Kompilera

Läs mer

Instuderingsfrågor, del B

Instuderingsfrågor, del B Uppgift 1. Vad skrivs ut i nedanstående programsekvenser? Uppgift 2. Instuderingsfrågor, del B a) int minutes = 10; while ( minutes

Läs mer

Föreläsning 2. Föreläsning 2

Föreläsning 2. Föreläsning 2 Operationer på datatypen Notation Föreläsning 2 Primitiva datatyper Selektering Betydelse Resultatets datatyp a+b addition a-b subtraktion a*b multiplikation a/b division a%b modulus (rest vid division)

Läs mer

732G Linköpings universitet 732G11. Johan Jernlås. Översikt. Repetition. Muddy. Funktioner / metoder. Punktnotation. Evalueringsordning

732G Linköpings universitet 732G11. Johan Jernlås. Översikt. Repetition. Muddy. Funktioner / metoder. Punktnotation. Evalueringsordning Varför? 732G11 Linköpings universitet 2011-02-08 Varför? 1 2 3 Varför? 4 5 Medelvärde av 5000 tal Varför? while-loopen int nrofints = 5000; int [] integers = new int [ nrofints ]; int pos = 0; while (

Läs mer

1 Iteration. 1.1 for-satsen

1 Iteration. 1.1 for-satsen 1 Iteration Iteration innebär en upprepning, repetition av satser. Vi har nu sett hur en villkorssats kan välja att utföra ett satsblock beroende på om ett villkor är uppfyllt, selektion. För selektion

Läs mer

Objektorienterad programmering

Objektorienterad programmering Objektorienterad programmering Föreläsning 2: primitiva datatyper och selektering Dr. Alex Gerdes Dr. Carlo A. Furia Hösttermin 2016 Chalmers University of Technology Några meddelande Studentrepresentanter

Läs mer

Föreläsning 2. Föreläsning 2

Föreläsning 2. Föreläsning 2 Operationer på datatypen Notation Föreläsning 2 Primitiva datatyper Selektering Betydelse Resultatets datatyp a+b addition a-b subtraktion a*b multiplikation a/b division a%b modulus (rest vid division)

Läs mer

Klassdeklaration. Metoddeklaration. Parameteröverföring

Klassdeklaration. Metoddeklaration. Parameteröverföring Syntax: Class Declaration Modifier Class Body Basic Class Member Klassdeklaration class Class Member Field Declaration Constructor Declaration Method Declaration Identifier Class Associations Motsvarar

Läs mer

Föreläsning 2. Primitiva datatyper Selektering. Operationer på datatypen double. Motsvarande operationer finns för float. a + b addition double

Föreläsning 2. Primitiva datatyper Selektering. Operationer på datatypen double. Motsvarande operationer finns för float. a + b addition double Föreläsning 2 Primitiva datatyper Selektering Operationer på datatypen double Notation Betydelse Resultatets datatyp a + b addition double a - b subtraktion double a * b multiplikation double a / b division

Läs mer

OOP Objekt-orienterad programmering

OOP Objekt-orienterad programmering OOP F2:1 OOP Objekt-orienterad programmering Föreläsning 2 Deklaration och tilldelning Programsatser Tilldelning Input/Output Selektion Deklaration och tilldelning OOP F2:2 int x; double d; char ch; boolean

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

Lösningsförslag till tentamen

Lösningsförslag till tentamen Uppgift 1 Lösningsförslag till tentamen 140423 a) Vad kompilatorn klagar på är att metoden Math.sqrt() inte finns! Detta kan ju verka något mystiskt eftersom vi alla vet att det i klassen Math finns en

Läs mer

F4. programmeringsteknik och Matlab

F4. programmeringsteknik och Matlab Programmeringsspråk Föreläsning 4 programmeringsteknik och Matlab 2D1312/ 2D1305 Introduktion till Java Kompilering, exekvering, variabler, styrstrukturer 1 Ett program är en eller flera instruktioner

Läs mer

PROGRAMMERING-Java Omtentamina

PROGRAMMERING-Java Omtentamina PROGRAMMERING-Java Omtentamina Nicolina Månsson 2007-08 13 Tentamensinstruktioner Poängsättning Hela tentamen omfattar 41 poäng. Poäng för varje uppgift står angivet inom parentes före varje uppgift. -

Läs mer

Föreläsning 3-4 Innehåll. Diskutera. Metod. Programexempel med metod

Föreläsning 3-4 Innehåll. Diskutera. Metod. Programexempel med metod Föreläsning 3-4 Innehåll Diskutera Vad gör programmet programmet? Föreslå vilka satser vi kan bryta ut till en egen metod. Skriva egna metoder Logiska uttryck Algoritm för att beräkna min och max Vektorer

Läs mer

PROGRAMMERING-Java TENTAMINA

PROGRAMMERING-Java TENTAMINA PROGRAMMERING-Java TENTAMINA Nicolina Månsson 2010-03-17 Tentamensinstruktioner Poängsättning Hela tentamen omfattar 42 poäng. Poäng för varje uppgift står angivet inom parentes före varje uppgift. - För

Läs mer

Föreläsning 1 & 2 INTRODUKTION

Föreläsning 1 & 2 INTRODUKTION Föreläsning 1 & 2 INTRODUKTION Denna föreläsning Vad händer under kursen? praktisk information Kursens mål vad är programmering? Skriva små program i programspråket Java Skriva program som använder färdiga

Läs mer

Dagens föreläsning. Repetition. Repetition - Programmering i C. Repetition - Vad C består av. Repetition Ett första C-program

Dagens föreläsning. Repetition. Repetition - Programmering i C. Repetition - Vad C består av. Repetition Ett första C-program Dagens föreläsning Programmeringsteknik för Ingenjörer VT05 Föreläsning 3-4 Repetition Datatyper Uttryck Operatorer Satser Algoritmer Programmeringsteknik VT05 2 Repetition Repetition - Programmering i

Läs mer

Instuderingsfrågor, del A

Instuderingsfrågor, del A Uppgift 1. Instuderingsfrågor, del A Objektorienterad programmering, Z1 Vilka av följande identifierare är ogiltiga i Java? Motivera. a) Benny b) any.time c) any_time d) intnumber e) INTNUMBER f) 1stStreet

Läs mer

Laboration 1. "kompilera"-ikonen "exekvera"-ikonen

Laboration 1. kompilera-ikonen exekvera-ikonen Programmerade system I1 Syfte Laboration 1. Syftet med denna laboration är dels att göra dej bekant med de verktyg som kan vara aktuella i programmeringsarbetet, dels ge en första inblick i att skriva

Läs mer

"if"-satsen. Inledande programmering med C# (1DV402)

if-satsen. Inledande programmering med C# (1DV402) "if"-satsen Upphovsrätt för detta verk Detta verk är framtaget i anslutning till kursen Inledande programmering med C# vid Linnéuniversitetet. Du får använda detta verk så här: Allt innehåll i verket if-satsen

Läs mer

Metoder och top-down design

Metoder och top-down design Metoder och top-down design Föreläsning 4 TDA540 - Objektorienterad Programmering Meddelande Bara några dagar kvar till laboration 1 deadlinen Läs textboken, läsanvisningar finns på hemsidan Kom ihåg flödet:

Läs mer

TENTAMEN OOP

TENTAMEN OOP TENTAMEN OOP 2013-08-08 ANVISNINGAR Påbörja varje ny uppgift på nytt blad. Skriv endast på ena sidan av bladen. Skriv tydligt - oläsbara svar beaktas ej. BETYGSÄTTNING Max antal poäng är 30. För att bli

Läs mer

Föreläsning 1 & 2 INTRODUKTION

Föreläsning 1 & 2 INTRODUKTION Föreläsning 1 & 2 INTRODUKTION Denna föreläsning Vad händer under kursen? praktisk information Kursens mål vad är programmering? Skriva små program i programspråket Java Skriva program som använder färdiga

Läs mer

System.out.println("Jaså du har "+ antalhusdjur+ " husdjur"); if ( antalhusdjur > 5 ) System.out.println("Oj det var många);

System.out.println(Jaså du har + antalhusdjur+  husdjur); if ( antalhusdjur > 5 ) System.out.println(Oj det var många); 1 Villkor och styrsatser I de program vi sett tidigare har programkörning inneburit att sats efter sats utförts i den ordning de skrivits i källkoden. Vi har inte kunna ändra programmets uppförande beroende

Läs mer

Programstruktur och terminologi. Programmet producerar följande utskrift i terminalfönstret: Ett Javaprogram består av en eller flera klasser

Programstruktur och terminologi. Programmet producerar följande utskrift i terminalfönstret: Ett Javaprogram består av en eller flera klasser // En första version av BankKonto-klassen class BankKonto { private String namn; private long nr; private double saldo; private double ränta; // Klassen TestaBankKonto // Klassens uppgift är att skapa

Läs mer

Lösningsförslag till tentamen

Lösningsförslag till tentamen Uppgift 1 Lösningsförslag till tentamen 140828 a) public class MyMax { public static void main(string[] args) { //5 ändra String till String[] System.out.println("Maximum is: " + maximum(5, 7)); //2 ändra

Läs mer

Tentamen , Introduktion till Java, dtaa98, dtea53

Tentamen , Introduktion till Java, dtaa98, dtea53 Mittuniversitetet 2007-09-01 Institutionen för informationsteknologi och medier Sid:1(3) dtaa98, dtea53 Martin Kjellqvist; Linda Karlsson, Ulf Reiman Lösningsansatser Tentamen 2007-09-01, Introduktion

Läs mer

Objektorienterad programmering

Objektorienterad programmering Objektorienterad programmering Föreläsning 4: metoder och top-down design Dr. Alex Gerdes Dr. Carlo A. Furia Hösttermin 2016 Chalmers University of Technology Några meddelande Bara några dagar kvar till

Läs mer

Outline. For. I istället för att följa det normala ordningen, man ändra den. I i Java får man inte göra hopp hur som helst

Outline. For. I istället för att följa det normala ordningen, man ändra den. I i Java får man inte göra hopp hur som helst Outline Objektorienterad Programmering (TDDC77) Föreläsning IV: while, for, do while, switch, arrayer Ahmed Rezine IDA, Linköpings Universitet Hösttermin 2016 Ordning Villkorliga hopp I Normalt sett så

Läs mer

Lite om felhantering och Exceptions Mer om variabler och parametrar Fält (eng array) och klassen ArrayList.

Lite om felhantering och Exceptions Mer om variabler och parametrar Fält (eng array) och klassen ArrayList. Institutionen för Datavetenskap Göteborgs universitet HT2009 DIT011 Objektorienterad programvaruutveckling GU (DIT011) Föreläsning 3 Innehåll Lite om felhantering och Exceptions Mer om variabler och parametrar

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 8 SLUMPTAL, SIMULERING + INTRODUKTION TILL VEKTORER

Föreläsning 8 SLUMPTAL, SIMULERING + INTRODUKTION TILL VEKTORER Föreläsning 8 SLUMPTAL, SIMULERING + INTRODUKTION TILL VEKTORER Från laboration 3 till 4 I laboration 3 har du implementerat klasser implementerat metoder i klasserna I laboration 4 kommer du att implementera

Läs mer

Inledande programmering med C# (1DV402) Summera med while"-satsen

Inledande programmering med C# (1DV402) Summera med while-satsen Summera med while"-satsen Upphovsrätt för detta verk Inledande programmering med C# (1DV402) Detta verk är framtaget i anslutning till kursen Inledande programmering med C# vid Linnéuniversitetet. Du får

Läs mer

F5 Selektion och iteration. ID1004 Objektorienterad programmering Fredrik Kilander

F5 Selektion och iteration. ID1004 Objektorienterad programmering Fredrik Kilander F5 Selektion och iteration ID1004 Objektorienterad programmering Fredrik Kilander fki@kth.se Boolska uttryck Boolska uttryck använder sig av jämförelseoperatorer < > = ==!= Resultatets datatyp är boolean

Läs mer

Lösningsförslag till tentamen

Lösningsförslag till tentamen Uppgift 1 Lösningsförslag till tentamen 170314 a) Falskt. Talområdet för ett 8-bitars tal på tvåkomplementsform är -128 till 127. b) Sant. c) Falskt, HTTP är ett kommunikationsprotokoll som används för

Läs mer

Föreläsnings 9 - Exceptions, I/O

Föreläsnings 9 - Exceptions, I/O Föreläsnings 9 - Exceptions, I/O Josef Svenningsson Tisdag 6/11 Undantag - Exceptions Kommer ni ihåg det här programmet? Det var ett av de första ni såg i första föreläsningen. import javax.swing.*; public

Läs mer

EDAA20 Programmering och databaser. Mål komprimerat se kursplanen för detaljer. Om att lära sig programmera. Föreläsning 1-2 Innehåll.

EDAA20 Programmering och databaser. Mål komprimerat se kursplanen för detaljer. Om att lära sig programmera. Föreläsning 1-2 Innehåll. EDAA20 Programmering och databaser Mål komprimerat se kursplanen för detaljer Läsperiod 1 7.5 hp anna.axelsson@cs.lth.se http://cs.lth.se/edaa20 Mer information finns på kursens webbsida samt på det utdelade

Läs mer

Dagens föreläsning. Sett i datorsalarna. Mer om arrayer. Matriser. Formatering av utskrifter. Inläsning med hjälp av Scanner-klassen

Dagens föreläsning. Sett i datorsalarna. Mer om arrayer. Matriser. Formatering av utskrifter. Inläsning med hjälp av Scanner-klassen (5 februari 2018 F4 1 ) Dagens föreläsning Sett i datorsalarna Mer om arrayer Matriser Formatering av utskrifter Inläsning med hjälp av Scanner-klassen Ett exempel med dialogrutor Java-doc Kommer först

Läs mer

Lektion Java Grunder. Javas historia. Programmeringsspråket Java. Skillnaderna mellan Java och C++ JVM (Javas Virtuella Maskin)

Lektion Java Grunder. Javas historia. Programmeringsspråket Java. Skillnaderna mellan Java och C++ JVM (Javas Virtuella Maskin) Lektion Java Grunder Javas historia Ursprungligen utvecklades Java (1991) för att användas i olika typer av konsumentelektronik (mikrovågsugnar, videoapparater) av programmerare på Sun. Språket kallades

Läs mer

//Använd main som ett "handtag" för att hålla ihop programmet. //Själva programmet finns i övriga klasser.

//Använd main som ett handtag för att hålla ihop programmet. //Själva programmet finns i övriga klasser. /*==================================================================== Detta program hör ihop med dokumentet EXEMPEL_AVERAGE_POINTS.PDF där det finns förklaringar. ======================================================================*/

Läs mer

Föreläsning REPETITION & EXTENTA

Föreläsning REPETITION & EXTENTA Föreläsning 18 19 REPETITION & EXTENTA Programmeringsteknik på 45 minuter Klasser och objekt Variabler: attribut, lokala variabler, parametrar Datastrukturer Algoritmer Dessa bilder är inte repetitionsbilder

Läs mer

F2 Datatyper och variabler. ID1004 Objektorienterad programmering Fredrik Kilander

F2 Datatyper och variabler. ID1004 Objektorienterad programmering Fredrik Kilander F2 Datatyper och variabler ID1004 Objektorienterad programmering Fredrik Kilander fki@kth.se Datatyper Java är ett starkt typat språk Varje slags data har en datatyp Datatyp Javasyntax Exempel Teckensträng

Läs mer

Malmö högskola 2012/2013 Teknik och samhälle

Malmö högskola 2012/2013 Teknik och samhälle Laboration 5 Avsikten med laborationen är att du ska träna på att använda iterationer i dina program. I vanlig ordning placerar du dina lösningar i paketet laboration5. Uppgifterna är lätt matematiska

Läs mer

Föreläsning 9-10 Innehåll

Föreläsning 9-10 Innehåll Föreläsning 9-10 Innehåll Inläsning från textfil, utskrift från textfil Vektorer med objekt Matriser Datavetenskap (LTH) Föreläsning 9-10 HT 2018 1 / 41 Klassen Scanner Läsa från System.in Vi har tidigare

Läs mer

Programmering med Java. Grunderna. Programspråket Java. Programmering med Java. Källkodsexempel. Java API-exempel In- och utmatning.

Programmering med Java. Grunderna. Programspråket Java. Programmering med Java. Källkodsexempel. Java API-exempel In- och utmatning. Programmering med Java Programmering med Java Programspråket Java Källkodsexempel Källkod Java API-exempel In- och utmatning Grunderna Ann Pan panda@nada.kth.se Rum 1445, plan 4 på Nada 08-7909690 Game.java

Läs mer

Lösningsförslag till tentamen

Lösningsförslag till tentamen Uppgift 1 Lösningsförslag till tentamen 160315 a) Falskt. 8A 16 = 138 10 = 10001010 2 b) Falskt. Enligt Moores lag fördubblas antal transistorer som ryms på en given yta var 18:e månad. c) Sant. Sant.

Läs mer

Dagens föreläsning. Repetition. Repetition - Programmering i C. Repetition - Vad C består av. Repetition Ett första C-program

Dagens föreläsning. Repetition. Repetition - Programmering i C. Repetition - Vad C består av. Repetition Ett första C-program Dagens föreläsning Programmeringsteknik för Ingenjörer VT05 Föreläsning 3-4 Repetition Datatyper Uttryck Operatorer Satser Algoritmer Programmeringsteknik för ingenjörer, VT06 2 Repetition Repetition -

Läs mer

Föreläsning 2. Täcker material från lektion 1, 2, 3 och 4:

Föreläsning 2. Täcker material från lektion 1, 2, 3 och 4: (22 januari 2016 F2.1 ) Föreläsning 2 Täcker material från lektion 1, 2, 3 och 4: Datatyper Aritmetik Tecken och strängar Klasser, Objekt Metoder Villkor, villkorssatser och iterationer main-metoden Kodstandard

Läs mer

Föreläsning 3: Typomvandling, villkor och val, samt textsträngar

Föreläsning 3: Typomvandling, villkor och val, samt textsträngar Föreläsning 3: Typomvandling, villkor och val, samt textsträngar Camilla Kirkegaard camilla.kirkegaard@liu.se Linköpings universitet Sweden October 14, 2013 1 Innehåll n n n n n Repetition Typomvandlingar

Läs mer

Föreläsning 2 Programmeringsteknik och C DD1316. Mikael Djurfeldt

Föreläsning 2 Programmeringsteknik och C DD1316. Mikael Djurfeldt Föreläsning 2 Programmeringsteknik och C DD1316 Mikael Djurfeldt Föreläsning 2 Programmeringsteknik och C Python introduktion Utskrift Inläsning Variabler Datatyp Aritmetiska operatorer Omvandling

Läs mer

Lösningsförslag till tentamen

Lösningsförslag till tentamen Uppgift 1 Lösningsförslag till tentamen 150418 a) i) Utskriften blir: ii) [8, 3, 9, 4, 5] Metoden mystery flyttar om elementen i fältet arr på så sätt att alla elementen, förutom det första, flyttas ett

Läs mer

OOP Objekt-orienterad programmering

OOP Objekt-orienterad programmering OOP F4:1 OOP Objekt-orienterad programmering Föreläsning 4 Metoder klass-metoder instans-metoder Metoder - subrutiner OOP F4:2 Kod som utför en viss operation. Ligger i olika klasser och anropas via operatorn.

Läs mer

Introduktion till Datalogi DD1339. Föreläsning 3 29 sept 2014

Introduktion till Datalogi DD1339. Föreläsning 3 29 sept 2014 Introduktion till Datalogi DD1339 Föreläsning 3 29 sept 2014 Ett lite intelligentare program? Klassen Rectangle Rectangle height width color setheight setwidth getcolor getarea Rectangle public class Rectangle{

Läs mer

Uppgift: Algoritm för att beräkna kontrollsiffran i ett personnummer givet de 9 första siffrorna. Torrsimning av algoritm för personnummer

Uppgift: Algoritm för att beräkna kontrollsiffran i ett personnummer givet de 9 första siffrorna. Torrsimning av algoritm för personnummer F6 Observera att när man utvecklar program så är inte alla lösningar på vägen korrekta. Speciellt den här gången så finns många OH med program som inte fungerar eftersom det är just det vi skall se på

Läs mer

Föreläsning 8. Klassen String Mer om fält Klassen ArrayList

Föreläsning 8. Klassen String Mer om fält Klassen ArrayList Föreläsning 8 Klassen String Mer om fält Klassen ArrayList Standardklassen String Texter handhas i Java med standardklassen String. Ett objekt av klassen String består av en följd av tecken, dvs element

Läs mer

Föreläsning 5&6 LOGISKA VARIABLER; IMPLEMENTERA KLASSER; MER ALGORITMER

Föreläsning 5&6 LOGISKA VARIABLER; IMPLEMENTERA KLASSER; MER ALGORITMER Föreläsning 5&6 LOGISKA VARIABLER; IMPLEMENTERA KLASSER; MER ALGORITMER Logiska uttryck datatypen boolean Logiska uttryck kan ha två möjliga värden, true eller false. Variabler av typen boolean kan tilldelas

Läs mer

Föreläsning 2, vecka 8: Repetition

Föreläsning 2, vecka 8: Repetition TDA 548: Grundläggande Programvaruutveckling Föreläsning 2, vecka 8: Repetition Magnus Myréen Chalmers, läsperiod 1, 2016-2017 Idag Metoder och terminologi Referensvärden och arrays Interface och ritning

Läs mer

Dagens text. Programmeringsteknik. Mer om Scanner-klassen. Dialogrutor (klassen JOptionPane) Bubbelsortering. Omslagsklasser.

Dagens text. Programmeringsteknik. Mer om Scanner-klassen. Dialogrutor (klassen JOptionPane) Bubbelsortering. Omslagsklasser. (16 februari 2016 F5.1 ) Dagens text Programmeringsteknik Mer om Scanner-klassen Dialogrutor (klassen JOptionPane) Bubbelsortering ArrayList Omslagsklasser Arbetsexempel (16 februari 2016 F5.2 ) Pokertärningar

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

Lösningsförslag till tentamen

Lösningsförslag till tentamen Uppgift 1 Lösningsförslag till tentamen 150117 a) Utskriften blir: 7 Metoden returnerar värdet av den största siffran som ingår i talet som skickas till metoden. b) Utskriften blir k= 5 a= [3, 1] b= [3,

Läs mer

Lite om reella tal. Programmering. I java. Om operatorers associativitet och prioritet

Lite om reella tal. Programmering. I java. Om operatorers associativitet och prioritet Programmering hh.se/db2004 Föreläsning 4: Fält samt Input/Output Verónica Gaspes www2.hh.se/staff/vero www2.hh.se/staff/vero/programmering Lite om reella tal Vad kan man göra med reella tal? Utöver de

Läs mer

Hej Då, Karel! Programmering. Vårt första Javaprogram. hh.se/db2004. Java. Grundtyper, variabler och arrayer

Hej Då, Karel! Programmering. Vårt första Javaprogram. hh.se/db2004. Java. Grundtyper, variabler och arrayer Programmering hh.se/db2004 Föreläsning 3: Java. Grundtyper, variabler och arrayer Hej Då, Karel! Verónica Gaspes www2.hh.se/staff/vero www2.hh.se/staff/vero/programmering Center for Research on Embedded

Läs mer

Variabler och konstanter

Variabler och konstanter Variabler och konstanter Deklareras automatisk när man stoppar in data i dem. X = 7 Y = A Z = Kalle Definieras av att de har: ett namn (X) en datatyp (Integer) ett värde (t.ex. 7) Lagras i datorns minne!

Läs mer

Datatyper och kontrollstrukturer. Skansholm: Kapitel 2) De åtta primitiva typerna. Typ Innehåll Defaultvärde Storlek

Datatyper och kontrollstrukturer. Skansholm: Kapitel 2) De åtta primitiva typerna. Typ Innehåll Defaultvärde Storlek De åtta primitiva typerna Java, datatyper, kontrollstrukturer Skansholm: Kapitel 2) Uppsala Universitet 11 mars 2005 Typ Innehåll Defaultvärde Storlek boolean true, false false 1 bit char Tecken \u000

Läs mer

732G Linköpings universitet 732G11. Johan Jernlås. Översikt. Repetition. Muddy cards. Slingor

732G Linköpings universitet 732G11. Johan Jernlås. Översikt. Repetition. Muddy cards. Slingor 732G11 Linköpings universitet 2011-02-01 1 2 3 Strukturdiagram Strukturdiagram används för att visa hur ett program fungerar. Man kan se alla val och upprepningar som sker i programmet. Består av tre (!)

Läs mer

Malmö högskola 2008/2009 CTS

Malmö högskola 2008/2009 CTS Laboration 5 Avsikten med laborationen är att du ska träna på att använda iterationer i dina program. I vanlig ordning placerar du dina lösningar i paketet laboration5. Uppgifterna är lätt matematiska

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 2016-03-17 Skrivtid: 1400 1900 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

Dagens föreläsning. Sett i datorsalarna. Mer om arrayer. Matriser. Formatering av utskrifter. Inläsning med hjälp av Scanner-klassen

Dagens föreläsning. Sett i datorsalarna. Mer om arrayer. Matriser. Formatering av utskrifter. Inläsning med hjälp av Scanner-klassen (10 februari 2019 F4 1 ) Dagens föreläsning Sett i datorsalarna Mer om arrayer Matriser Formatering av utskrifter Inläsning med hjälp av Scanner-klassen (10 februari 2019 F4 2 ) Hört och sett if-loop Skall

Läs mer

Objektorienterad programmering. Fält som funktionsresultat. Mer om fält: att uppdatera ett parameterfält. Kontrast: Parametrar av primitiv typ

Objektorienterad programmering. Fält som funktionsresultat. Mer om fält: att uppdatera ett parameterfält. Kontrast: Parametrar av primitiv typ orienterad programmering Föreläsning 3 Exempel: Telefonboken Fält som funktionsresultat Exempel Definiera static double[] vectorsum(double[] a, double[] b) Betrakta sedan följande kodavsnitt:... double[]

Läs mer

Omtentamen för TDA540 Objektorienterad Programmering. Institutionen för Datavetenskap CTH HT-17, TDA540. Dag: , Tid:

Omtentamen för TDA540 Objektorienterad Programmering. Institutionen för Datavetenskap CTH HT-17, TDA540. Dag: , Tid: Omtentamen för TDA540 Objektorienterad Programmering Institutionen för Datavetenskap CTH HT-17, TDA540 Dag: 2018-08-30, Tid: 14.00-18.00 Ansvarig: Examinator: Alex Gerdes Carlo A. Furia Förfrågningar:

Läs mer

Heltalsrepresentation. Fler byggstenar. Overflow och Underflow. TvŒ-komplement. FlyttalsvŠrden. Fyra heltalstyper. Tecken-bit

Heltalsrepresentation. Fler byggstenar. Overflow och Underflow. TvŒ-komplement. FlyttalsvŠrden. Fyra heltalstyper. Tecken-bit Fler byggstenar Heltalsrepresentation Fyra heltalstyper Intern data representation Typomvandlingar Fler operatorer VŠljande & upprepande satser Tecken-bit by te t short t int t 7 bitar 15 bitar 31 bitar

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

Lösningar till tentauppgifterna sätts ut på kurssidan på nätet idag kl 19. Omtentamen i Programmering C, 5p, fristående, kväll, 040110.

Lösningar till tentauppgifterna sätts ut på kurssidan på nätet idag kl 19. Omtentamen i Programmering C, 5p, fristående, kväll, 040110. 1(8) ÖREBRO UNIVERSITET INSTITUTIONEN FÖR TEKNIK Lösningar till tentauppgifterna sätts ut på kurssidan på nätet idag kl 19. Denna tenta kommer att vara färdigrättad On 14/1-04 och kan då hämtas på mitt

Läs mer

Föreläsning 3: Booleans, if, switch

Föreläsning 3: Booleans, if, switch TDA 545: Objektorienterad programmering Föreläsning 3: Booleans, if, switch Magnus Myréen Chalmers, läsperiod 1, 2015-2016 Påminnelse om klasser och objekt Boll boll1 = new Boll(5,12); skapar ett nytt

Läs mer

Klassen String Mer om fält Något om inläsning

Klassen String Mer om fält Något om inläsning Standardklassen String TDA43 I Programmerade system Föreläsning (OH-bilder 8) Klassen String Mer om fält Något om inläsning Christer Carlsson Texter handhas i Java med standardklassen String. Ett objekt

Läs mer

Hur ser ett Java-program ut?

Hur ser ett Java-program ut? (27 augusti 2012 Repetitionsmaterial 1 ) Hur ser ett Java-program ut? // Ett första Java-program som skriver // ut ett meddelande på terminalen public class HelloWorld { public static void main(string

Läs mer

Programmeringsteknik I

Programmeringsteknik I Programmeringsteknik I Föreläsning 2: Grundläggande Java Johan Öfverstedt Java Grundläggande begrepp Datatyper Selektion if Räckvidd (scope) Iteration while Klasser Objekt Metoder Metodhuvudet Kodstandarden

Läs mer

Det är principer och idéer som är viktiga. Skriv så att du övertygar examinatorn 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 examinatorn om att du har förstått dessa även om detaljer kan vara felaktiga. Tentamen Programmeringsteknik I 2011-03-17 Skrivtid: 1400-1700 Hjälpmedel: Java-bok 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

Läs mer

Laboration 1. "kompilera"-ikonen "exekvera"-ikonen

Laboration 1. kompilera-ikonen exekvera-ikonen Syfte Laboration 1. Objektorienterad programmering, Z1 Syftet med denna laboration är dels att göra dej bekant med de verktyg som kan vara aktuella i programmeringsarbetet, dels ge en första inblick i

Läs mer

JAVAUTVECKLING LEKTION 3

JAVAUTVECKLING LEKTION 3 JAVAUTVECKLING LEKTION 3 2016 Mahmud Al Hakim mahmud.al.hakim@nackademin.se www.alhakim.se AGENDA Numeriska typer Inläsning av numerisk data Numeriska typomvandlingar Standardklassen Math Villkorskonstruktioner

Läs mer

Villkor och tester. Utförande satser bygger upp metoderna, man brukar finindela detta i: sekvenser. Ett program består i princip av: selektioner (val)

Villkor och tester. Utförande satser bygger upp metoderna, man brukar finindela detta i: sekvenser. Ett program består i princip av: selektioner (val) Villkor och tester Ett program består i princip av: Deklarationer som inför variabler, dvs namngivna minnesceller som används för att lagra data. int a; double radie=1.0, yta; double d = 4.5; String s

Läs mer