Sidan är under uppdatering. Labbar, popup07Här hittar ni kursens labbar. UppläggKursen innehåller fyra labbar, som är en del av problemlösningsmomentet i kursen. Varje labb innehåller ett antal labbuppgifter. Målet med labbarna är att ni ska utveckla ett återanvändbart kodbibliotek med implentationer av användbara algorimer och datastrukturer. Labbarna är inte obligatoriska, men det finns två goda skäl att göra dem ändå; dels ger de betygspoäng (se examination), dels kommer ni att ha möjlighet att använda det ni gjort på labbarna till hemtalen men framför allt under problemlösningssessionerna. Bedömning av labbarBedömningen av inlämnade labbar består av två delar: automatiskt test att koden verkar vara korrekt, samt okulärbesiktning av koden. Den automatiska testningen består av uppgifter hos Kattis. Till varje labbuppgift finns en motsvarande uppgift hos Kattis som testar att ni har löst labbuppgiften korrekt. Okulärbesiktningen består i att vi kollar på koden och kontrollerar att den är väl dokumenterad och strukturerad (se vidare Krav på koden nedan). InlämningEn labbupgift anses inlämnad om motsvarande Kattis-uppgift är löst vid deadline för labben. Vid granskningen kommer vi att titta på den senaste godkända inskickningen som inkom innan deadline. Tänk på att det är den koden som kommer att granskas (och som därför ska vara bra kommenterad). Obs! Alla i labbgruppen måste skicka in en lösning på Kattis-uppgiften. DeadlinesDeadlines anges i labblydelserna. Krav på kodenAllmänna kravKoden ska vara kommenterad och snyggt strukturerad. Till varje uppgift ger vi förslag på vad funktionen/klassen som ska implementeras kan ta för parametrar och vad den kan returnera. Obs! Detta är dock inte något som ni behöver följa slaviskt, om ni tycker att det blir snyggare att göra på något annat sätt går det bra, så länge funktionen fortfarande löser uppgiften som ska lösas. FörfattareFörfattarens (eller författarnas, om det är en grupp) namn ska finnas som en kommentar högst upp i koden. DokumentationAlla funktioners och klassers funktionalitet ska vara dokumenterad med kommentarer i koden. FelhanteringIdealiskt vore förstås om era algoritmer och datastrukturer var helt robusta och generella, men det kan vara svårt. Exceptionella fall måste hanteras på något sätt, t.ex. genom att kasta undantag eller åtminstone genom att ni dokumenterar dem. Mer detaljerade kravHär följer tolkningar, tillämpningar och tumregler som har med kraven att göra. Det är inte en uttömmande lista på vad som behövs.
|