Tentamen i Grundläggande programmering STS, åk 1 lördag 2002-05-25



Relevanta dokument
Tentamen i Grundläggande programmering STS, åk 1 fredag

Tentamen i Grundläggande programmering STS, åk

Tentamen i Grundläggande programmering STS, åk

Tentamen i Grundläggande programmering STS, åk 1 fredag

Laboration 1 - Grunderna för OOP i Java

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.

OOP Tentamen

TENTAMEN PROGRAMMERING I JAVA, 5P SOMMARUNIVERSITETET

TENTAMEN OOP

Grundläggande programmering, STS 1, VT Sven Sandberg. Föreläsning 14

Tentamen i Programmering

OOP Omtenta

JAVA Mer om klasser och objektorientering

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

Det finns en referensbok (Java) hos vakten som du får gå fram och läsa men inte ta tillbaka till bänken.

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

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 OOP

Tentamen i Programmeringsteknik I

Modern Programmering (2546) Tentamen lördag

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

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

Det finns en referensbok (Java) hos tentavakten som du får gå fram och läsa men inte ta tillbaka till bänken.

TENTAMEN: Objektorienterad programmering. Läs detta! Skriv din tentamenskod på varje blad (så att vi inte slarvar bort dem).

OOP Tentamen

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

Det finns en referensbok (Java) hos vakten som du får gå fram och läsa men inte ta tillbaka till bänken.

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

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

DUGGA: Objektorienterade applikationer. Läs detta! Uppgifterna är inte avsiktligt ordnade efter svårighetsgrad.

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

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

OOP Tenta

OOP Tentamen

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 OOP

Tentamen i Programmeringsteknik I

Tentamen i EDA011 Programmeringsteknik för F, E, I, π och N

Sortering. Om du följt dessa steg korrekt så ska böckerna nu vara sorterade.

Dugga i Grundläggande programmering STS, åk

OOP Omtenta

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.

Det finns en referensbok (Java) hos tentavakten som du får gå fram och läsa men inte ta tillbaka till bänken.

Tentamen i Programmeringsteknik I

LÖSNINGSFÖRSLAG TENTAMEN

Tentamen i Programmering grundkurs och Programmering C

Tentamen. Grundläggande programmering i Java A 5p, DTAA

Grundläggande programmering med C# 7,5 högskolepoäng

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

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

OOP Omtenta

Tentamen DE12, IMIT12, SYST12, ITEK11 (även öppen för övriga)

Det finns en referensbok (Java) hos vakten som du får gå fram och läsa men inte ta tillbaka till bänken.

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

PROGRAMMERING-Java TENTAMINA

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

OBJEKTORIENTERAD PROGRAMVARUUTVECKLING. Övningstentamen 1

Tentamen på kursen DA7351, Programmering , kl Malmö högskola Teknik och samhälle. DA7351, Programmering

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

a. Vilka av följande påståenden är riktiga? Observera att felaktigt valda påståenden ger poängavdrag. (4p)

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

INFORMATIK - MED SYSTEMVETENSKAPLIG INRIKTNING, GRK/A (1-30 HP)

DELPROV 1 I DATAVETENSKAP

Objektorienterad Programkonstruktion, DD1346 FACIT. Tentamen , kl

Grundläggande programmering, STS 1, VT Sven Sandberg. Föreläsning 12

PROGRAMMERING-JAVA TENTAMINA

Tentamen ID1004 Objektorienterad programmering April 7, 2015

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

Det finns en referensbok (Java) hos tentavakten som du får gå fram och läsa men inte ta tillbaka till bänken.

TENTAMEN. Kurs: Objektorienterad programmeringsmetodik 5DV133 Ansvarig lärare: Anders Broberg. VT-13 Datum: Tid: kl

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

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

Institutionen för TENTAMEN CTH VT-15 Datavetenskap TDA540. Tentamen för TDA540 Objektorienterad programmering

DAT043 Objektorienterad Programmering

Laboration 13, Arrayer och objekt

4 13 / %.; 8 </" '': " / //&' " " ' * TelefonKostnad +,-%&. #!" $% " &' . > / ' 5 /' * 13/ &' static Math 1+" &'/ % 12 "" static "' * 1 /") %& &

Föreläsning 2 Objektorienterad programmering DD1332. Typomvandling

Högskolan Dalarna sid 1 av 7 DI-institutionen Hans-Edy Mårtensson Sten Sundin

OOP Exempel Tentamen 2007

Tentamen i Programmeringsteknik MN

Tänk på följande: Det finns en referensbok (Java) hos tentavakten som du får gå fram och läsa men inte ta tillbaka till bänken.

2 b) Följande finns definierat: public class Käk String titel = "Chili con carne"; Krydda[] kryddor = new Krydda[10]; kryddor[0] = new Krydda("Svartpe

OOP Tenta

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

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

Lösningsförslag till tentamen i EDA011/EDA017 Programmeringsteknik för F, E, I, π och N 25 maj 2009

Subklasser och arv Inledning till grafik (JFrame och JPanel). Något om interface. Objektorienterad programvaruutveckling GU (DIT011) Subklasser

Praktikum i programmering

Tentamen i. för D1 m fl, även distanskursen. lördag 26 februari 2011

Vem är vem på kursen. Objektorienterad programvaruutveckling GU (DIT011) Kursbok Cay Horstmann: Big Java 3rd edition.

Det finns en referensbok (Java) hos tentavakten som du får gå fram och läsa men inte ta tillbaka till bänken.

Lösningsförslag till tentamen i EDA011, lördagen den 16 december 2006

7,5 högskolepoäng. Objektorienterad systemutveckling I Provmoment: Ladokkod: 21OS1B Tentamen ges för: Lycka till! /Peter & Petter

Lösningsförslag. Programmeringsmetodik, KV: Java och OOP. 17 januari 2004

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

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

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

Tentamen OOP

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

OOP Objekt-orienterad programmering

Transkript:

Tentamen i Grundläggande programmering STS, åk 1 lördag 2002-0-2 Skrivtid: 09.00 14.00 Hjälpmedel: Inga Lärare: Anders Berglund. Elena Fersman besöker tentan vid två tillfällen: cirka kl. 10.30 samt cirka kl. 11.30. Anders Berglund är inte anträffbar under tentan. Observera: Programkod ska skrivas enligt god programmeringssed för Java och objektorienterad programmering. Uppgifterna är inte ordnade efter svårighetsgrad. Läs igenom hela tentan först. Kom ihåg att fylla i försättsbladet ordentligt. Om du är osäker på någon fråga eller uppfattar någon uppgift som oklar, gör ett antagande som du motiverar och förklarar väl. På de uppgifter där du ska skriva programkod, kan du också skriva en förklaring, om du inte är säker på att din lösning är riktig. En sådan ger visserligen inga poäng, men kan hjälpa till vid rättningen att förstå tankarna bakom en lösning Skriv programkod rimligt indenterad och med bra variabelnamn. På så sätt underlättas rättningen. 0% av tentans totala poängantal garanterar betyget godkänt Skriv endast en uppgift per blad och skriv bara på ena sidan av papperet, dvs. ett nytt blad för varje uppgiftsnummer, medan deluppgifter (a, b, c etc.) får skrivas på samma blad. Fyll i försättsbladet ordentligt! Skriv namn på alla papper. Referera inte mellan olika svar. Lycka till!

FÖRSÄTTSBLAD Denna sida ska ifylld placeras först bland de papper du lämnar in Uppgift 1 2 3 4 6 7 bonus Besvarad ange i förekommande fall vilka deluppgifter du har löst ifylles av institutionen Namnteckning: Namn: Personnummer:

1. Ord, bara ord (4p) Förklara kortfattat med precist följande termer: a) syntax (i samband med programmeringsspråk) b) semantik (i samband med programmeringsspråk) c) parameter (i samband med programmeringsspråk) d) lättviktig komponent (i samband med grafik i Java) e) tungviktig komponent (i samband med grafik i Java) f) komposition (i samband med programmeringsspråk) g) klassmetod (i samband med programmeringsspråk) h) Applet (i samband med Java) 2. Det snurrar (6p) Vilken utskrift ger nedanstående program? Om du anser att programmet avbryts med ett felmeddelande, går i en evig loop eller något sådant, ska du även kort förklara varför import extra.*; public class GorVadKlass{ public static int GorVad(int x) { if (x == 0) return 1; if (x == 1) return 1; return GorVad(x-1) + GorVad(x-2); public static void main(string[] args) { for (int i = ; i <= 8; i++) { Std.out.println(GorVad(i)); 3. OOP (6p) Ange kortfattat tre väsentliga argument till varför objekt-orienterade programmeringsspråk är lämpliga för mycket programutveckling. 4. Personlig integritet (4p) Under föreläsningen i dataetik behandlades begreppet personlig integritet. Ge exempel på en kränkning av den personliga integriteten och förklara kortfattat varför den är en kränkning. Ge din förklaring i högst fyra meningar, gärna kortare

. Tabeller (20p) Läs hela uppgiften, innan du påbörjar någon deluppgift! Studera nedanstående programskelett. På ett antal ställen saknas kod. Din uppgift är att lösa nedanstående deluppgifter på ett sådant sätt, att lösningarna passar in i programskelettet och med det provkörningsexempel som finns sist i uppgifter. Programmet ska fråga först efter ett ensamt tal och sedan ytterligare ett antal tal. De inmatade talen ska skrivas ut. Därefter ska alla förekomster av det första talet i de övriga inmatade talen tas bort. Till sist ska alla tal skrivas ut igen. a) I denna deluppgift ska du skriva de rader som saknas i metoden in(), så att metoden, när den anropas, läser in ett antal tal till mintabell. Inmatningen ska avslutas med 0. Du ska i denna uppgift använda en while-slinga. b) I denna deluppgift ska du skriva de rader som saknas i metoden ut(), så att metoden, när den anropas, skriver ut de element som är skilda från 0 (noll). Du ska i denna deluppgift använda en for-loop. c) I denna deluppgift ska du skriva de rader som saknas i metoden remove(int x). Metoden ska ta bort alla förekomster av talet x ut arrayen. Du avgör själv vilka programspråkskonstruktioner du vill använda. d) I denna deluppgift ska du skriva de rader som saknas i huvudprogrammet. Körexemplet visar vad huvudprogrammet ska göra. Skriv huvudprogrammet mycket enkelt. Du får utnyttja att samtliga tal i en array, när den skapas, automatiskt av Java sätts till 0. Du får också anta att användaren aldrig kommer att försöka mata in mer än ett litet antal tal - aldrig 100 stycken tal, eller ett antal, ungefär lika stort som 100 (såsom 98 eller 99). (Detta antagande kan vara till hjälp beroende på hur du väljer att lösa uppgiften). forts på nästa sida

forts från föregående sida import extra.*; public class TabellKlass { private int[] mintabell = new int[100]; public void in() { Std.out.println("Ge ett antal tal. Avsluta med 0."); int tp = Std.in.readInt(); public void skriv() { public void remove(int x) { public static void main(string[] args) { TabellKlass mittobjekt = new TabellKlass(); Std.out.println("Ge det tal som ska tas bort"); int bort = Std.in.readInt(); Provkörning: Ge det tal som ska tas bort Ge ett antal tal. Avsluta med 0. 6 3 4 6 0 Talen före 6 3 4 6 Talen efter 6 3 4 6

6. Bilar (20p) Tyvärr har du gett upp dina studier vid STS programmet för att börja som bilhandlare. Dock, du vill ha nytta av vad du har lärt dig och vill datorisera lagret av begagnade bilar. I detta syfte skriver du en klass Bil, som beskriver en begagnad bil i lagret. Varje bil har ett märkesnamn och ett modellnamn (båda får lagras som strängar). För varje bil finns det ett inpris (det du som bilhandlare betalar för bilen) och ett utpris (det pris du säljer bilen för). Utpriset beräknas från inpriset, med en procentsats. Normalt är denna 120% (dvs. en bil som du har köpt för 10 000.- säljer du för 12 000.-). Ibland är det dock sommarrea och procentsatsen sjunker, eller vårrusning, då du höjer priserna. Alla förändringar i priserna sker genom ändringar av denna procentsats. Procentsatsen är densamma för alla bilar. Det innebär att när du ändrar procentsatsen så förändras priset för alla bilar. Skriv nu denna klass. För att få full poäng på uppgiften, måste du skriva klassen med de variabler som finns i klassen en konstruktor en metod som skriver ut all information om en bil, inklusive de båda priserna en metod som låter dig ange en ny procentsatsen ett enkelt huvudprogram, som använder dessa metoder. Huvudprogrammet behöver inte ha texter som hjälper användaren, vara genomtänkt etc., utan är enbart tänkt att kunna fungera som ett provkörningsexempel för dessa metoder. Du behöver inte skriva några andra metoder än de som anges. Du får göra all in- och utmatning enkel. Tänk på att programmet ska illustrera en god programmeringssed för funktionella språk. 7. Klasser och sån't (6p) Studera nedanstående ord: Magsäck, hund, kattdjur, häst, däggdjur, djur, talgoxe, svans, husse/matte, leopard, tamkatt Relatera orden till varandra med hjälp av begreppen arv, komposition, känner till. Om du vill, kan du skriva en förklaring till de relationer du har beskrivit. Skriv i så fall förklaringen på ett separat papper. En sådan förklaring ger inga poäng, men kan underlätta rättningen. Glad sommar!!