Programmering och datastrukturer, 8 hp

Programming and Data Structures, 8 credits

TDDC76

Kursen är nedlagd. Gavs sista gången HT 2023. Ersätts av TDDE71.

Huvudområde

Datateknik Datavetenskap

Utbildningsnivå

Grundnivå

Kurstyp

Programkurs

Examinator

Klas Arvidsson

Studierektor eller motsvarande

Ola Leifler

Undervisningstid

Preliminär schemalagd tid: 98 h
Rekommenderad självstudietid: 115 h
VOF = Valbar / Obligatorisk / Frivillig
Kursen ges för Termin Period Block Språk Ort/Campus VOF
6CMED Civilingenjör i medicinsk teknik 5 (HT 2021) 1, 2 2, 2 Svenska Linköping, Valla O
6CYYY Civilingenjör i teknisk fysik och elektroteknik 5 (HT 2021) 1, 2 2, 2 Svenska Linköping, Valla O
6CYYI Civilingenjör i teknisk fysik och elektroteknik - internationell, franska 5 (HT 2021) 1, 2 2, 2 Svenska Linköping, Valla O
6CYYI Civilingenjör i teknisk fysik och elektroteknik - internationell, japanska 5 (HT 2021) 1, 2 2, 2 Svenska Linköping, Valla O
6CYYI Civilingenjör i teknisk fysik och elektroteknik - internationell, kinesiska 5 (HT 2021) 1, 2 2, 2 Svenska Linköping, Valla O
6CYYI Civilingenjör i teknisk fysik och elektroteknik - internationell, spanska 5 (HT 2021) 1, 2 2, 2 Svenska Linköping, Valla O
6CYYI Civilingenjör i teknisk fysik och elektroteknik - internationell, tyska 5 (HT 2021) 1, 2 2, 2 Svenska Linköping, Valla O
6KFYN Fysik och nanovetenskap, kandidatprogram 5 (HT 2021) 1, 2 2, 2 Svenska Linköping, Valla V
6KMAT Matematik, kandidatprogram 5 (HT 2021) 1, 2 2, 2 Svenska Linköping, Valla O

Huvudområde

Datateknik, Datavetenskap

Utbildningsnivå

Grundnivå

Fördjupningsnivå

G2X

Kursen ges för

  • Civilingenjörsprogram i medicinsk teknik
  • Civilingenjörsprogram i teknisk fysik och elektroteknik - internationell
  • Civilingenjörsprogram i teknisk fysik och elektroteknik
  • Kandidatprogram i fysik och nanovetenskap
  • Kandidatprogram i matematik

Särskild information

Yi: En grundkurs i programmering läses under utlandsåret alt TDDC74, TDDC76

Rekommenderade förkunskaper

Grundkurs i programmering, speciellt grundläggande färdigheter i problemlösning och konstruktion av små program. Grundläggande färdigheter i användning datorer och vana vid unixbaserade datorsystem.

Lärandemål

Kursens ska ge fördjupade kunskaper i programmering, speciellt procedurell och objektorienterad programmering i programspråket C++, och kunskaper om vanligt förekommande datastrukturer och algoritmer. Efter genomgången kursen ska studenten:

  • kunna konstruera och implementera program i programspråket C++.
  • kunna tillämpa objektorienterad programutvecklingsmetodik.
  • känna till och kunna använda vanligt förekommande datastrukturer och algoritmer.

Kursinnehåll

Föreläsningarna, lektioner och laborationer behandlar programspråket C++ och dess programmeringsomgivning, objektorienterad analys och design, programmering i C++, datastrukturer och algoritmer.

  • imperativ programmering i C++ (variabler, konstanter, deklarationer, uttryck, satser, funktioner, grundläggande datatyper och datastrukturer).
  • klasser (deklaration, datamedlemmar, medlemsfunktioner, nästlade typer, åtkomstspecifikation för medlemmar, konstruktorer, destruktorer, härledning/arv, polymorfi, dynamisk typkontroll och typomvandling).
  • objektorienterad programutvecklingsmetodik (objektorienterad analys, design och kodning).
  • användning av C++ standardbibliotek (in- och utmatning, tecken- och stränghantering, containrar).
  • datastrukturer: listor, stackar, köer, prioritetsköer, träd, speciellt sökträd, hashtabeller, heapar, speciellt binära heapar.
  • algoritmer: sökning och sortering.

Undervisnings- och arbetsformer

Kursen består av föreläsningar, lektioner, laborationer och hemarbete (för litteraturstudier, lösning av laborationsuppgifter, projektarbete och hemtentamen).

Examination

UPG4Frivillig individuell reflektionsuppgift0 hpU, G
UPG3Datorbaserade inlämningsuppgifter1.5 hpU, G
LAB2En obligatorisk laborationskurs3.5 hpU, G, VG
PRA1Ett obligatoriskt projekt3 hpU, G

Programmeringsuppgifterna övar och prövar studentens kunskaper och färdigheter i imperativ och objektorienterad programmering.
Projektet övar och prövar kunskaper och studentens färdigheter i objektorienterad analys, design och programmering samt att arbeta i en projektgrupp.

De datorbaserade inlämningsuppgifterna prövar studentens kunskaper om datastrukturer och algoritmer och är samtidigt ett tillfälle för inlärning.Slutbetyget för kursen bestäms utifrån kursmålen och hur många poäng respektive student samlat in under kursens gång. För betyg 3 krävs godkänt i varje obligatoriskt kursmoment. För betyg 4 krävs utöver kraven för betyg 3 minst 20 insamlade poäng. För betyg 5 krävs utöver kraven för betyg 3 minst 40 insamlade poäng. Poäng ges för prestationer som går utöver kraven för godkänt enligt de krav som anges för respektive uppgift.

Betygsskala

Fyrgradig skala, LiU, U, 3, 4, 5

Övrig information

Påbyggnadskurser: Kurser där goda kunskaper i procedurell eller objektorienterad programmering, speciellt i C++, förutsätts. Exempel på sådana kurser är kurser som behandlar kompilatorer och interpretatorer, databaser, processprogrammering, realtidsprogrammering, operativsystem, designmönster, programutvecklingsprojekt och programmering av parallelldatorer.

Om undervisnings- och examinationsspråk

Undervisningsspråk visas på respektive kurstillfälle på fliken "Översikt". Examinationsspråk relaterar till undervisningsspråk enligt nedan:

  • Om undervisningsspråk är Svenska ges kursen i sin helhet eller till stora delar på svenska. Observera att även om undervisningsspråk är svenska kan delar av kursen ges på engelska. Examinationsspråk är svenska. 
  • Om undervisningsspråk är Svenska/Engelska kan kursen i sin helhet ges på engelska vid behov. Examinationsspråk är svenska eller engelska. 
  • Om undervisningsspråk är Engelska ges kursen i sin helhet på engelska. Examinationsspråk är engelska. 

Övrigt

Kursen bedrivs på ett sådant sätt att både mäns och kvinnors erfarenhet och kunskaper synliggörs och utvecklas.

Planering och genomförande av kurs skall utgå från kursplanens formuleringar. Den kursvärdering som ingår i kursen skall därför genomföras med kursplanen som utgångspunkt. 

Institution

Institutionen för datavetenskap

Studierektor eller motsvarande

Ola Leifler

Examinator

Klas Arvidsson

Kurshemsida och andra länkar

http://www.ida.liu.se/~TDDC76/

Undervisningstid

Preliminär schemalagd tid: 98 h
Rekommenderad självstudietid: 115 h

Kurslitteratur

Böcker

  • Bjarne Stroustrup, (2013) The C++ Programming Language, 4/E Addison-Wesley
    Referensbok för dig som redan kan programera en del C++ eller liknande språk.
  • Stanley B. Lippman, Josée Lajoie, Barbara E. Moo, (2012) C++ Primer, 5/E Addison-Wesley
    Traditionell lärobok
Kod Benämning Omfattning Betygsskala
UPG4 Frivillig individuell reflektionsuppgift 0 hp U, G
UPG3 Datorbaserade inlämningsuppgifter 1.5 hp U, G
LAB2 En obligatorisk laborationskurs 3.5 hp U, G, VG
PRA1 Ett obligatoriskt projekt 3 hp U, G

Programmeringsuppgifterna övar och prövar studentens kunskaper och färdigheter i imperativ och objektorienterad programmering.
Projektet övar och prövar kunskaper och studentens färdigheter i objektorienterad analys, design och programmering samt att arbeta i en projektgrupp.

De datorbaserade inlämningsuppgifterna prövar studentens kunskaper om datastrukturer och algoritmer och är samtidigt ett tillfälle för inlärning.Slutbetyget för kursen bestäms utifrån kursmålen och hur många poäng respektive student samlat in under kursens gång. För betyg 3 krävs godkänt i varje obligatoriskt kursmoment. För betyg 4 krävs utöver kraven för betyg 3 minst 20 insamlade poäng. För betyg 5 krävs utöver kraven för betyg 3 minst 40 insamlade poäng. Poäng ges för prestationer som går utöver kraven för godkänt enligt de krav som anges för respektive uppgift.

Kursplan

För varje kurs ska en kursplan finnas. I kursplanen anges kursens mål och innehåll samt de särskilda förkunskaper som erfordras för att den studerande skall kunna tillgodogöra sig undervisningen.

Schemaläggning

Schemaläggning av kurser görs enligt, för kursen, beslutad blockindelning. 

Avbrott på kurs

Enligt rektors beslut om regler för registrering, avregistrering samt resultatrapportering (Dnr LiU-2015-01241) skall avbrott i studier registreras i Ladok. Alla studenter som inte deltar i kurs man registrerat sig på är alltså skyldiga att anmäla avbrottet så att kursregistreringen kan 
tas bort. Avanmälan från kurs görs via webbformulär, www.lith.liu.se/for-studenter/kurskomplettering?l=sv. 

Inställd kurs

Kurser med få deltagare ( < 10) kan ställas in eller organiseras på annat sätt än vad som är angivet i kursplanen. Om kurs skall ställas in eller avvikelse från kursplanen skall ske prövas och beslutas detta av dekanus. 

Riktlinjer rörande examination och examinator 

Se Beslut om Riktlinjer för utbildning och examination på grundnivå och avancerad nivå vid Linköpings universitet Dnr LiU-2019-00920, (http://styrdokument.liu.se/Regelsamling/VisaBeslut/917592). 

Examinator för en kurs ska inneha en läraranställning vid LiU i enlighet med LiUs anställningsordning, Dnr LiU-2017-03931 (https://styrdokument.liu.se/Regelsamling/VisaBeslut/622784). För kurser på avancerad nivå kan följande lärare vara examinator: professor (även adjungerad och gästprofessor), biträdande professor (även adjungerad), universitetslektor (även adjungerad och gästlektor), biträdande universitetslektor eller postdoktor. För kurser på grundnivå kan följande lärare vara examinator: professor (även adjungerad och gästprofessor), biträdande professor (även adjungerad), universitetslektor (även adjungerad och gästlektor), biträdande universitetslektor, universitetsadjunkt (även adjungerad och gästadjunkt) eller postdoktor. I undantagsfall kan även en Timlärare utses som examinator på både grund- och avancerad nivå, se Tekniska fakultetsstyrelsen vidaredelegationer. 

Examination

Principer för tentamina

Skriftlig och muntlig tentamen samt digital salstentamen och datortentamen ges minst tre gånger årligen; en gång omedelbart efter kursens slut, en gång i augustiperioden samt vanligtvis i en av omtentamensperioderna. Annan placering beslutas av programnämnden.

Principer för tentamensschemat för kurser som följer läsperioderna:

  • kurser som ges Vt1 förstagångstenteras i mars och omtenteras i juni och i augusti
  • kurser som ges Vt2 förstagångstenteras i maj och omtenteras i augusti och i oktober
  • kurser som ges Ht1 förstagångstenteras i oktober och omtenteras i januari och augusti
  • kurser som ges Ht2 förstagångstenteras i januari och omtenteras i mars och i augusti

Tentamensschemat utgår från blockindelningen men avvikelser kan förekomma främst för kurser som samläses/samtenteras av flera program samt i lägre årskurs.

För kurser som av programnämnden beslutats vara vartannatårskurser ges tentamina 3 gånger endast under det år kursen ges.

För kurser som flyttas eller ställs in så att de ej ges under något eller några år ges tentamina 3 gånger under det närmast följande året med tentamenstillfällen motsvarande dem som gällde före flyttningen av kursen.

När en kurs ges för sista gången ska ordinarie tentamen och två omtentamina erbjudas. Därefter fasas examinationen ut med tre tentamina samtidigt som tentamen ges i eventuell ersättningskurs under det följande läsåret. Om ingen ersättningskurs finns ges tre tentamina i omtentamensperioder under det följande läsåret. Annan placering beslutas av programnämnden. I samtliga fall ges dessutom tentamen ytterligare en gång under det därpå följande året om inte programnämnden föreskriver annat.

Om en kurs ges i flera perioder under året (för program eller vid skilda tillfällen för olika program) beslutar programnämnden/programnämnderna gemensamt om placeringen av och antalet omtentamina. 

Omprov övriga examinerande moment

För riktlinjer för omprov vid andra examinerande moment än skriftliga tentamina, digital salstentamina och datortentamina hänvisas till de generella LiU-riktlinjerna för examination och examinator, http://styrdokument.liu.se/Regelsamling/VisaBeslut/917592. 

Anmälan till tentamen

Fram till 31 januari 2021 gäller enligt tidigare riktlinjer: För deltagande i skriftlig tentamen, digital salstentamen och datortentamen krävs att den studerande gjort förhandsanmälan i Studentportalen under anmälningsperioden, dvs tidigast 30 dagar och senast 10 dagar före tentamensdagen. Anvisad sal meddelas fyra dagar före tentamensdagen via e-post. Studerande, som inte förhandsanmält sitt deltagande riskerar att avvisas om plats inte finns inom ramen för tillgängliga skrivningsplatser.

Från 1 februari 2021 gäller nya riktlinjer för anmälan till skriftliga salsskrivningar inklusive digitala tentamina i sal, Dnr LiU-2020-02033 (se beslut i regelsamlingen https://styrdokument.liu.se/Regelsamling/VisaBeslut/622682). 

Teckenförklaring till tentaanmälningssystemet:
  ** markerar att tentan ges för näst sista gången
  * markerar att tentan ges för sista gången 

Ordningsföreskrifter för studerande vid tentamensskrivningar

Se särskilt beslut i regelsamlingen: http://styrdokument.liu.se/Regelsamling/VisaBeslut/622682

Plussning

Vid Tekniska högskolan vid LiU har studerande rätt att genomgå förnyad examination (s.k. plussning) för högre betyg på skriftliga tentamina, digital salstentamina och datortentamina, dvs samtliga provmoment med modulkod TEN, DIT och DAT. På övriga examinationsmoment ges inte möjlighet till plussning, om inget annat anges i kursplan.

Plussning är ej möjlig på kurser som ingår i utfärdad examen.

Betyg och examinationsformer

Företrädesvis skall betygen underkänd (U), godkänd (3), icke utan beröm godkänd (4) och med beröm godkänd (5) användas. 

  • Kurser med skriftlig tentamen och digital salstentamen skall ge betygen (U, 3, 4, 5).
  • Kurser med stor del tillämpningsinriktade moment såsom laborationer, projekt eller grupparbeten får ges betygen underkänd (U) eller godkänd (G).
  • Examensarbete samt självständigt arbete ger betyg underkänd (U) eller godkänd (G).

Examinationsmoment och modulkoder

Nedan anges vad som gäller för de examinationsmoment med tillhörande modulkod som tillämpas vid Tekniska fakulteten vid Linköpings universitet. 

  • Skriftlig tentamen (TEN) och digital salstentamen (DIT) skall ge betyg (U, 3, 4, 5).
  • Examinationsmoment som kan ge betygen underkänd (U) eller godkänd (G) är laboration (LAB), projekt (PRA), kontrollskrivning (KTR), digital kontrollskrivning (DIK), muntlig tentamen (MUN), datortentamen (DAT), uppgift (UPG), hemtentamen (HEM).
  • Övriga examinationsmoment där examinationen uppfylls framför allt genom aktivt deltagande som basgrupp (BAS) eller moment (MOM) ger betygen underkänd (U) eller godkänd (G).
  • Examinationsmomenten Opposition (OPPO) och Auskultation (AUSK) inom examensarbetet ger betyg underkänd (U) eller godkänd (G).

Allmänt gäller att:

  • Obligatoriska kursmoment skall vara poängsatta och ges en modulkod.
  • Examinationsmoment som ej är poängsatt får ej vara obligatoriskt. Det är frivilligt att delta på dessa moment och information om det samt tillhörande villkor skall tydligt framgå i den beskrivande texten.
  • För kurser med flera examinationsmoment med graderad betygsskala skall det anges hur slutbetyg på kursen vägs samman.

För obligatoriska moment gäller att: Om det finns särskilda skäl, och om det med hänsyn till det obligatoriska momentets karaktär är möjligt, får examinator besluta att ersätta det obligatoriska momentet med en annan likvärdig uppgift. (I enlighet med LiU-riktlinjerna http://styrdokument.liu.se/Regelsamling/VisaBeslut/917592). 

För samtliga examinationsmoment gäller att: Om LiU: s koordinator för studenter med funktionsnedsättning har beviljat en student rätt till anpassad examination vid salstentamen har studenten rätt till det. Om koordinatorn istället har gett studenten en rekommendation om anpassad examination eller alternativ examinationsform, får examinator besluta om detta om examinator bedömer det möjligt utifrån kursens mål. (I enlighet med LiU-riktlinjerna http://styrdokument.liu.se/Regelsamling/VisaBeslut/917592).

Rapportering av examinationsresultat

Rapportering av den studerandes examinationsresultat sker på respektive institution.

Plagiering

Vid examination som innebär rapportskrivande och där studenten kan antas ha tillgång till andras källor (exempelvis vid självständiga arbeten, uppsatser etc) måste inlämnat material utformas i enlighet med god sed för källhänvisning (referenser eller citat med angivande av källa) vad gäller användning av andras text, bilder, idéer, data etc. Det ska även framgå ifall författaren återbrukat egen text, bilder, idéer, data etc från tidigare genomförd examination, exempelvis från kandidatarbete, projektrapporter etc. (ibland kallat självplagiering).

Underlåtelse att ange sådana källor kan betraktas som försök till vilseledande vid examination.

Försök till vilseledande

Vid grundad misstanke om att en student försökt vilseleda vid examination eller när en studieprestation ska bedömas ska enligt Högskoleförordningens 10 kapitel examinator anmäla det vidare till universitetets disciplinnämnd. Möjliga konsekvenser för den studerande är en avstängning från studierna eller en varning. För mer information se https://www.student.liu.se/studenttjanster/lagar-regler-rattigheter?l=sv.

Regler

Universitetet är en statlig myndighet vars verksamhet regleras av lagar och förordningar, exempelvis Högskolelagen och Högskoleförordningen. Förutom lagar och förordningar styrs verksamheten av ett antal styrdokument. I Linköpings universitets egna regelverk samlas gällande beslut av regelkaraktär som fattats av universitetsstyrelse, rektor samt fakultets- och områdesstyrelser. 

LiU:s regelsamling angående utbildning på grund- och avancerad nivå nås på http://styrdokument.liu.se/Regelsamling/Innehall/Utbildning_pa_grund-_och_avancerad_niva. 

Böcker

Bjarne Stroustrup, (2013) The C++ Programming Language, 4/E Addison-Wesley

Referensbok för dig som redan kan programera en del C++ eller liknande språk.

Stanley B. Lippman, Josée Lajoie, Barbara E. Moo, (2012) C++ Primer, 5/E Addison-Wesley

Traditionell lärobok

I = Introducera, U = Undervisa, A = Använda
I U A Moduler Kommentar
1. ÄMNESKUNSKAPER
1.1 Kunskaper i grundläggande matematiska och naturvetenskapliga ämnen (kurser på G1X-nivå)
X
LAB2
Grundläggande matematik
1.2 Kunskaper i grundläggande teknikvetenskapliga ämnen (kurser på G1X-nivå)
X
X
LAB2
PRA1
UPG3
A: Imperativ programmering
U: Datastrukturer och algoritmer, OOP
1.3 Fördjupade kunskaper, metoder och verktyg inom något av: matematik, naturvetenskap, teknik (kurser på G2X-nivå)
X
LAB2
PRA1
Objektorienterad programmering i C++
1.4 Väsentligt fördjupade kunskaper, metoder och verktyg inom något av: matematik, naturvetenskap, teknik (kurser på A1X-nivå)

                            
1.5 Insikt i aktuellt forsknings- och utvecklingsarbete

                            
2. INDIVIDUELLA OCH YRKESMÄSSIGA FÄRDIGHETER OCH FÖRHÅLLNINGSSÄTT
2.1 Analytiskt tänkande och problemlösning
X
X
LAB2
PRA1
Kravspecifikation, objektorienterad analys och design
2.2 Experimenterande och undersökande arbetssätt samt kunskapsbildning
X
LAB2
PRA1
Laborativt arbete, projektarbete, informationssökning
2.3 Systemtänkande
X
X
LAB2
PRA1
Modellering, avvägningar i val av lösningar
2.4 Förhållningssätt, tänkande och lärande
X
X
PRA1
Kreativt och kritiskt tänkande
Projektförslag och teknikval, slutföra projekt
2.5 Etik, likabehandling och ansvarstagande
X
LAB2
Följa god programmeringsed och stil
3. FÖRMÅGA ATT ARBETA I GRUPP OCH ATT KOMMUNICERA
3.1 Arbete i grupp
X
PRA1
Projektarbete i grupper om 4-6
3.2 Kommunikation
X
X
LAB2
PRA1
Skriftlig projektdokumentation (krav, analys, design, erfarenheter)
3.3 Kommunikation på främmande språk

                            
4. PLANERING, UTVECKLING, REALISERING OCH DRIFT AV TEKNISKA PRODUKTER OCH SYSTEM MED HÄNSYN TILL AFFÄRSMÄSSIGA OCH SAMHÄLLELIGA BEHOV OCH KRAV
4.1 Samhälleliga villkor, inklusive ekonomiskt, socialt och ekologiskt hållbar utveckling

                            
4.2 Företags- och affärsmässiga villkor

                            
4.3 Att identifiera behov samt strukturera och planera utveckling av produkter och system
X
PRA1
Specifikation, analys  av ett programvaruprojekt
4.4 Att konstruera produkter och system
X
PRA1
Design av ett programvaruprojekt
4.5 Att realisera produkter och system
X
PRA1
Konstruktion och testning av programvaruprojekt
4.6 Att ta i drift och använda produkter och system
X
Goda designprinciper för underhåll av mjukvara
5. PLANERING, GENOMFÖRANDE OCH PRESENTATION AV FORSKNINGS- ELLER UTVECKLINGSPROJEKT MED HÄNSYN TILL VETENSKAPLIGA OCH SAMHÄLLELIGA BEHOV OCH KRAV
5.1 Samhälleliga villkor, inklusive ekonomiskt, socialt och ekologiskt hållbar utveckling inom forsknings- och utvecklingsprojekt

                            
5.2 Ekonomiska villkor för forsknings- och utvecklingsprojekt

                            
5.3 Att identifiera behov samt strukturera och planera forsknings- eller utvecklingsprojekt
X
PRA1
Specifikation, anlys och design av ett programvaruprojekt
5.4 Att genomföra forsknings- eller utvecklingsprojekt
X
PRA1
Planera och genomföra konstruktion och testning av programvaruprojekt
5.5 Att redovisa och utvärdera forsknings- eller utvecklingsprojekt
X
PRA1
Erfarenhetsrapport

Denna flik innehåller det material som är publikt i Lisam. Den information som publiceras här är inte juridiskt bindande, sådant material hittar du under övriga flikar på denna sida.

Det finns inga filer att visa.