Programmeren (2018–2019)

Peter Dawyndt · Universiteit Gent

Welkom op de Dodona-cursus van het opleidingsonderdeel Programmeren (Universiteit Gent, faculteit Wetenschappen). Deze cursus bevat Python programmeeroefeningen die voorzien zijn van automatische feedback. De oefeningen zijn per programmeertechniek ingedeeld in tien reeksen.

Onderstaand leerpad bevat een reeks opdrachten die je wekelijks moet afwerken. Dit omvat onder meer de hoofdstukken uit het handboek die als voorbereiding op de hoorcolleges moeten gelezen worden, extra opdrachten als voorbereiding op het oplossen van de programmeeroefeningen, tips & tricks die je kunt gebruiken bij het oplossen van de oefeningen, en een reeks opgelegde oefeningen die wekelijks moeten ingediend worden voor dinsdagavond 22:00. Merk op dat de ISBN-oefeningen deel uitmaken van de opgelegde oefeningen en dus ook moeten ingediend worden voor de wekelijkse deadlines op dinsdag. Voorbeeldoplossingen van de ISBN-oefeningen vind je op Minerva. Hou zelf je leerpad in de gaten om te zien voor welke opgelegde oefeningen je reeds een (correcte) oplossing hebt ingediend.

De punten voor het opleidingsonderdeel Programmeren worden voor 20% (4/20) berekend op basis van de niet-periodegebonden evaluatie (dagelijks werk) en voor 80% (16/20) op basis van de periodegebonden evaluatie (examen). De niet-periodegebonden evaluatie (dagelijks werk) bestaat uit twee componenten die samen de score van de niet-periodegebonden evaluatie bepalen.

Voor het eerste deel van de niet-periodegebonden evaluatie krijgen de studenten een reeks van 60 oefeningen opgelegd. Op basis van de behandelde programmeertechnieken worden deze oefeningen onderverdeeld in 10 reeksen, waarbij elke reeks bestaat uit 6 opgelegde oefeningen. De eerste oefening van elke reeks is telkens een variant op het werken met ISBN-nummers. Een voorbeeldoplossing van deze oefening is gegeven op Minerva, en in een bijhorende instructievideo wordt uitgelegd hoe we tot deze voorbeeldoplossing gekomen zijn. Met deze ISBN-oefening zetten we uiteen hoe de nieuw aangebrachte programmeertechniek van de oefeningenreeks in de praktijk kan gebracht worden. Met deze voorbereiding kunnen de studenten zelf aan de slag om de programmeertechniek in de praktijk te brengen via het oplossen van de andere vijf opgelegde oefeningen uit de reeks. Studenten moeten hun oplossingen voor de opgelegde oefeningen van elke reeks (inclusief de ISBN-oefening) indienen via het online leerplatform Dodona tegen vooraf vastgelegde deadlines (telkens op de dinsdag om 22:00 volgend op de week van het werkcollege gewijd aan de oefeningenreeks). Op Dodona krijgen studenten een overzicht van hun status voor de opgelegde oefeningen, zodat ze makkelijk kunnen opvolgen voor welke oefeningen ze reeds een correcte oplossing hebben ingediend.

Voor het tweede deel van de niet-periodegebonden evaluatie organiseren we twee evaluatiemomenten tijdens de werkcolleges die volgen op het afwerken van vijf oefeningenreeksen. Bij deze evaluaties krijgen de studenten telkens twee uur de tijd om twee nieuwe programmeeroefeningen op te lossen. Hierbij kunnen ze gebruikmaken van het online leerplatform Dodona om de correctheid van hun oplossingen na te gaan. De ingediende oplossingen van deze evaluatie-oefeningen worden echter met de hand nagekeken door de lesgever en zijn begeleiders, en beoordeeld op correctheid, gebruikte programmeerstijl, keuzes gemaakt bij het gebruik van de verschillende programmeertechnieken en de kwaliteit van de oplossingsmethode. De moeilijkheidsgraad van deze evaluatie-oefeningen is lager dan deze van de oefeningen die tijdens de periodegebonden evaluatie (het examen) worden voorgelegd, aangezien we op dit tijdstip van het semester voornamelijk willen nagaan of de studenten de basisvaardigheden van het programmeren beheersen. Bovendien volgen deze evaluatiemomenten dezelfde procedure die gebruikt wordt tijdens de periodegebonden evaluatie, zodat studenten op basis van hun ervaring eventueel hun werkmethode kunnen bijsturen in voorbereiding naar het examen.

De score van de niet-periodegebonden evaluatie wordt bepaald volgens de formule s * c / a. Hierbij staat s voor de score die de studenten behaald hebben op basis van hun ingediende evaluatie-oefeningen (uitgedrukt op 20), c staat voor het aantal opgelegde oefeningen dat correct werd ingediend tegen de wekelijkse deadlines, en a staat voor het aantal opgelegde oefeningen (30 per evaluatiereeks). Een student die bijvoorbeeld 16/20 behaald heeft voor zijn evaluatie-oefeningen en alle 30 opgelegde oefeningen correct heeft ingediend voorafgaand aan de wekelijkse deadlines, krijgt voor die evaluatiereeks een score van 16 * 30/30 = 16 op 20. Als die student echter nog steeds 16/20 had behaald voor zijn evaluatie-oefeningen, maar slechts 18/30 opgelegde oefeningen correct had ingediend voorafgaand aan de wekelijkse deadlines, dan houdt die student slechts een score van 16 * 18 / 30 = 9.6 op 20 over.

Studenten krijgen zo snel mogelijk na een evaluatie per email hun score toegestuurd. Tijdens het daaropvolgende werkcollege krijgen de studenten ook de oplossingen die ze ingediend hebben tijdens de evaluatie terug, voorzien van feedback die aangeeft waar er verbeterpunten zijn die ze kunnen meenemen bij het verder oplossen van oefeningen of naar het examen.

De niet-periodegebonden evaluatie kan niet hernomen worden tijdens de tweede examenperiode. Voor de tweede examenperiode wordt enerzijds een score berekend rekening houdend met de punten behaald voor de niet-periodegebonden evaluatie (dus punten dagelijks werk gequoteerd op 4 samen met het examen gequoteerd op 16, zoals dat ook geldt voor de eerste examenperiode) en wordt anderzijds ook een score berekend zonder rekening te houden met de punten behaald voor de niet-periodegebonden evaluatie (examenresultaat rechtstreeks gequoteerd op 20). De eindscore voor de tweede examenperiode is het maximum van de voorgaande twee berekeningen.

Tijdens de periodegebonden evaluatie (examen) krijgen de studenten 3.5 uur om drie programmeeroefeningen op te lossen. Daarvoor kunnen de studenten opnieuw gebruik maken van de Dodona omgeving om hun oplossingen in te dienen en feedback te krijgen op de correctheid en de programmeerstijl ervan. Voor het bepalen van de examenscore worden de ingediende oplossingen evenwel opnieuw met de hand nagekeken en beoordeeld.

You are not a member of this course.

Register

Exercise series

reeks 01: variabelen, expressies en statements
October 02, 2018 22:00

reeks 02: voorwaardelijke opdrachten
October 09, 2018 22:00

reeks 03: controlelussen
October 16, 2018 22:00

Title Class progress Status
ISBN
Generators
The frog prince
Early warning
Elevator paradox
Billiards table

reeks 04: strings
October 23, 2018 22:00

Title Class progress Status
ISBN
Piece of cake
Torn numbers
The Ghent University prime number
Suskewiet
Bible codes

reeks 05: functies
October 30, 2018 22:00

Title Class progress Status
ISBN
Table talk
Stop codons
Reversals
Pangrammatic window
Rövarspråket

reeks 06: lijsten en tuples
November 20, 2018 22:00

Title Class progress Status
ISBN
Lineup
Recoupling
Doomsday clock
Columnar transposition
Queens, knights and pawns

reeks 07: meer over functies en modules
November 27, 2018 22:00

Title Class progress Status
ISBN
The last marble
Obscure holidays
Dawkins' weasel
Curling
Five up

reeks 08: verzamelingen en dictionaries
December 04, 2018 22:00

Title Class progress Status
ISBN
Caucasus
Calculator spelling
Merry christmas
Snowball numbers
Smoke signals

reeks 10: objectgericht programmeren
December 21, 2018 22:00

Title Class progress Status
ISBN
National Register Number
The Hippocrates code
Mad Libs
Blindsided
Quipu
Title Class progress Status
Babbage's number
Numeronym
Title Class progress Status
Turn, turn, turn
Palindrome in Scrabble
Title Class progress Status
HIV 11/25
Garland words
Title Class progress Status
The language of science
Jupiter-C
Title Class progress Status
Mind-boggling card trick
Boxing Day
Title Class progress Status
Lipogram
Burnt pancakes
Title Class progress Status
Pillow talk
Geohash
Patience is a virtue
Title Class progress Status
Timeless
LetterWise
Red is the new black
Title Class progress Status
Dobble
The Parsons code
Audition
Title Class progress Status
Belgian numbers
The Bixby letter
Geohash-36
Title Class progress Status
Ellison words
Fuse
Knockout
Title Class progress Status
Brush strokes
Wandering fingers
Beaufort