C-Kurs/Übungsaufgaben: Unterschied zwischen den Versionen
(→Die Aufgaben) |
(→Die Aufgaben: Musterloesung 1.VL hinzugefuegt) |
||
Zeile 54: | Zeile 54: | ||
| Gabriel P. | | Gabriel P. | ||
| seba(2010) | | seba(2010) | ||
− | | | + | | [[Ckurs2010/Pythagoras-Triplet/Musterloesung | Pythagoras-Triplet]] |
|- bgcolor="#E8E8E8" | |- bgcolor="#E8E8E8" | ||
| [[Ckurs2009/Fibonacci-Folge|Fibonacci-Folge]] | | [[Ckurs2009/Fibonacci-Folge|Fibonacci-Folge]] | ||
Zeile 62: | Zeile 62: | ||
| Paul B. | | Paul B. | ||
| [[Benutzer:Mario|Mario]] (2010) | | [[Benutzer:Mario|Mario]] (2010) | ||
− | | | + | | [[Ckurs2009/Fibonacci-Folge/Musterlösung | Fibonacci-Folge]] |
|- bgcolor="#F5F5F5" | |- bgcolor="#F5F5F5" | ||
| [[Ckurs2009/digitalesSchloesserKnacken|digitales Schloesser knacken]] | | [[Ckurs2009/digitalesSchloesserKnacken|digitales Schloesser knacken]] | ||
Zeile 70: | Zeile 70: | ||
| Paul B. | | Paul B. | ||
| Eugen R. (2010) | | Eugen R. (2010) | ||
− | | | + | | [[Ckurs2009/digitalesSchloesserKnacken/Musterlösung | digitales Schloesser knacken]] |
|- bgcolor="#E8E8E8" | |- bgcolor="#E8E8E8" | ||
| [[Ckurs2009/Rekursives_arbeiten|Rekursives Arbeiten]] | | [[Ckurs2009/Rekursives_arbeiten|Rekursives Arbeiten]] | ||
Zeile 78: | Zeile 78: | ||
| Eugen R. | | Eugen R. | ||
| Paul B.(2010) | | Paul B.(2010) | ||
− | | | + | | [[Ckurs2009/Rekursives_arbeiten/Musterlösung | Rekursives Arbeiten]] |
|- bgcolor="#F5F5F5" | |- bgcolor="#F5F5F5" | ||
| [[Ckurs2009/Base64 | Base64]] | | [[Ckurs2009/Base64 | Base64]] | ||
Zeile 86: | Zeile 86: | ||
| Sebastian D. | | Sebastian D. | ||
| Paul B.(2010) | | Paul B.(2010) | ||
− | | | + | | [[Ckurs2009/Base64/Musterlösung | Base64]] |
|- bgcolor="#E8E8E8" | |- bgcolor="#E8E8E8" | ||
| [[Ckurs2009/EingabeAusgabe | Ein- und Ausgabe]] | | [[Ckurs2009/EingabeAusgabe | Ein- und Ausgabe]] | ||
Zeile 94: | Zeile 94: | ||
| [[Benutzer:Mario|Mario]] | | [[Benutzer:Mario|Mario]] | ||
| nion (2009), | | nion (2009), | ||
− | | | + | | [[Ckurs2009/EingabeAusgabe/Musterlösung | Ein- und Ausgabe]] |
|- bgcolor="#F5F5F5" | |- bgcolor="#F5F5F5" | ||
| [[Ckurs2009/Taschenrechner | Taschenrechner]] | | [[Ckurs2009/Taschenrechner | Taschenrechner]] | ||
Zeile 102: | Zeile 102: | ||
| [[Benutzer:Mario|Mario]] | | [[Benutzer:Mario|Mario]] | ||
| [[Benutzer:Tkroenert|TKroenert]] (2009), | | [[Benutzer:Tkroenert|TKroenert]] (2009), | ||
− | | | + | | [[Ckurs2009/Taschenrechner/Musterlösung | Taschenrechner]] |
|- bgcolor="#E8E8E8" | |- bgcolor="#E8E8E8" | ||
| [[Ckurs2009/VerschachtelteSchleifen | Verschachtelte Schleifen]] | | [[Ckurs2009/VerschachtelteSchleifen | Verschachtelte Schleifen]] | ||
Zeile 110: | Zeile 110: | ||
| [[Benutzer:Dank|Daniel K.]] | | [[Benutzer:Dank|Daniel K.]] | ||
| AlexanderK (2009), | | AlexanderK (2009), | ||
− | | | + | | |
|- bgcolor="#F5F5F5" | |- bgcolor="#F5F5F5" | ||
| [[Ckurs2009/Glückspiel | Glücksspiel]] | | [[Ckurs2009/Glückspiel | Glücksspiel]] | ||
Zeile 118: | Zeile 118: | ||
| [[Benutzer:Dank|Daniel K.]] | | [[Benutzer:Dank|Daniel K.]] | ||
| AlexanderK (2009), | | AlexanderK (2009), | ||
− | | | + | | [[Ckurs2009/Glückspiel/Musterlösung | Glückspiel]] |
|- bgcolor="#E8E8E8" | |- bgcolor="#E8E8E8" | ||
| [[Ckurs/Buchstaben_zählen | Buchstaben zählen]] | | [[Ckurs/Buchstaben_zählen | Buchstaben zählen]] | ||
Zeile 142: | Zeile 142: | ||
| [[Benutzer:Mario|Mario]] | | [[Benutzer:Mario|Mario]] | ||
| Martin K. (2009), | | Martin K. (2009), | ||
− | | | + | | [[Ckurs2009/Taschenrechner2.0/Musterlösung | Taschenrechner ''2.0'']] |
|- bgcolor="#E8E8E8" | |- bgcolor="#E8E8E8" | ||
| [[Ckurs2009/Call by reference | Call by reference]] | | [[Ckurs2009/Call by reference | Call by reference]] | ||
Zeile 150: | Zeile 150: | ||
| sping | | sping | ||
| nion (2009), Alex K. (2010) | | nion (2009), Alex K. (2010) | ||
− | | | + | | [[Ckurs2009/Call by reference/Musterlösung | Call by reference]] |
|- bgcolor="#F5F5F5" | |- bgcolor="#F5F5F5" | ||
| [[Ckurs2010/String to Double | String to Double]] | | [[Ckurs2010/String to Double | String to Double]] |
Version vom 14. September 2011, 12:46 Uhr
Wir haben jeder Aufgabe eine Einschätzung ihrer Schwierigkeit auf einer Skala von 1 bis 10 vorangestellt. Bei dieser Einschätzung sind wir von einem Gehirn ausgegangen, für welches das jeweilige Themengebiet völlig neu ist, das jedoch schon ein ganz gutes Verständnis dafür hat wie eine Programmiersprache denn so funktioniert. Entsprechend kann eine schwer bewertete Aufgabe aus einem frühen Themengebiet für manch einen sehr einfach oder eine leicht bewertete aus einem späten Themengebiet für einen anderen sehr schwer sein. Es ist nur ein Wert, der euch helfen soll eure nächste Aufgabe zu wählen.
Falls ihr Anmerkungen zu den Aufgaben habt, könnt ihr die Diskussionsseiten der jeweiligen Aufgaben nutzen.
Inhaltsverzeichnis
Schwierigkeitsgrade
- Reines Tutorial. Man muss nicht viel selbst denken
- ...
- Leichte Übungsaufgabe. Studies, die noch eher unsicher sind werden hier gut begleitet.
- ...
- Typische Aufgabe. Man muss den Kopf benutzen, bekommt an schwierigen Stellen aber Hilfestellungen.
- ...
- Herausfordernd, eher etwas für Studies die etwas fitter sind.
- ...
- Auch erfahrene Programmierer werden hier ein bis zwei Übungen beschäftigt sein
- Tja, die Idee war da. Wir finden sie auch gut, aber es könnte wirklich anstrengend werden.
Die Aufgaben
Aufgabe | Schwierigkeit | Vorwissen | Lerneffekte | Bearbeiter | Korrektur gelesen | Musterlösung |
---|---|---|---|---|---|---|
Von der Konsole zum HelloWorld | 1 | 1. VL | Konsole benutzen, Hello World | Sebastian D. | Mario (2009), | |
Fakultät | 2 | 1. VL | Schleifen | Sebastian D. | Daniel (2009), | |
Pythagoras-Triplet | 2 | 1. VL | Schleifen if-Bedingungen |
Gabriel P. | seba(2010) | Pythagoras-Triplet |
Fibonacci-Folge | 2 | 1. VL | Funktionen Rekursion |
Paul B. | Mario (2010) | Fibonacci-Folge |
digitales Schloesser knacken | 4 | 1. VL | Kontrollstrukturen Bitweise Operatoren |
Paul B. | Eugen R. (2010) | digitales Schloesser knacken |
Rekursives Arbeiten | 3-5 | 1. VL | Bekannte Operatoren wie + durch Funktionen succ und neg nachbilden | Eugen R. | Paul B.(2010) | Rekursives Arbeiten |
Base64 | 6 | 1. VL | Operatoren | Sebastian D. | Paul B.(2010) | Base64 |
Ein- und Ausgabe | 1 | 1. Tut | Einlesen von Benutzereingaben Ausgabe derselben |
Mario | nion (2009), | Ein- und Ausgabe |
Taschenrechner | 3 | 1. Tut | Eingabe+Ausgabe Mathematische Operatoren |
Mario | TKroenert (2009), | Taschenrechner |
Verschachtelte Schleifen | 3 | 1. Tut | Umgang mit mehreren verschachtelten Schleifen | Daniel K. | AlexanderK (2009), | |
Glücksspiel | 3 | 1. Tut | Anwenden von Fallunterscheidungen und Einlesen von Werten aus der Konsole | Daniel K. | AlexanderK (2009), | Glückspiel |
Buchstaben zählen | 4 | 1. Tut | Array, Dateien lesen | Alex K. | Gabriel (2010) | vorhanden bitte reinstellen |
Wochentagsrechnung | 5 | 1. Tut | Einlesen von Benutzereingaben Mathematikverständniss |
Mario | nion (Musterlösung noch nicht vorhanden) (2009), | |
Taschenrechner 2.0 | 8 | 1. Tut | Knobeln Komplexes Aufgaben lösen |
Mario | Martin K. (2009), | Taschenrechner 2.0 |
Call by reference | 4 | 3. VL | Einfache Anwendung von &/* | sping | nion (2009), Alex K. (2010) | Call by reference |
String to Double | 5 | 3. VL | Original-Dokumentation anwenden (Opengroup, man pages) Pointer auf Pointer Const correctness Strings |
sping | Eugen R. (2010) | vorhanden bitte reinstellen |
Text processing | 4, 6 | 3. VL | Strings Pointer-Arithmetik Pointer auf Pointer Refactoring |
sping | Mario (2009), | |
Palindrome | 4 | 3. VL | Pointer und Strings | Daniel K. | nion (2009), | |
(Pointer) Swapping | 5 | 3. VL | Pointer und Arrays benutzen, generisches swap | Katrin | Katrin (2010) | |
Matrizenmultiplikation | 6 | 3. VL | Mehrdimensionale Arrays const correctness |
sping | Mario (2009), | |
3D mit C | 6-9 | 3. VL | Mathematische Rechenoperationen, Algorithmik | AndreasF | Mario (2010) | |
Arrayuebergabe | 4/5 | 3. VL | Einlesen von Benutzereingaben Pointer und Pointerarithmetik |
nion | Martin K. (2009), | |
Studentendatenbank | 4 | 3. VL | struct, Pointer, Arrays | AlexanderK | Gabriel (2010) | |
Punktstrukturen | 2-3 | 2. VL | Structs, Unions, Pointer | Florian (2010) | Alex K. (2010) | |
Sammelbestellung | 2-5 | 3. VL | Listen, Pointer, Speicherverwaltung | Florian | Mario (2009), | |
Zahlen sagen | 5 | 3. VL | Umgang mit Zeichenketten | Martin K. | Paul B. (w.i.p.) | |
DTMF-Encoder | 8 | 2. VL | Pointer, Arrays, Umgang mit Audiodaten | Alexander K. | ||
Compiler, Präprozessor, Header Files | 3 | 3. Tut | Arbeiten mit mehreren Quellcode-Dateien, Kompilieren und Linken, Header-Dateien und #include, debugging-Makro verwenden | Katrin | AndyF (2010) | |
Bus Error | 8 | 4. Tut | Pointer, wie entsteht ein bus error | Katrin | Mario (2010) | |
BubbleSort Debugging | 5 | 4. Tut | Debuggen eines Programmes mit gdb | aeichner | ||
Debugging | 1-8 | 4. Tut | Debuggen einer Anwendung nach Wahl | aeichner | ||
CKDU | 3-10 | 3. VL | Live-Coding-aufgabe dem CKurs 2010 | Sping | TKroenert (2010) | |
Code Layout | 3 | 3. VL | Kleinere Codeschipsel mit kleinen Unsauberkeiten | Daniel | TKroenert (2010) | |
Refactoring | 5-9 | 3. VL | Wie verbessere ich den Quellcode eines Programmes. | Daniel | ||
Cat | 6 | 1. Tut | Arbeiten mit Dateien Kommandozeilenparameter |
nion | sping (2009), | |
Pong | 7 | 5. Tut | allgemeiner Programmablauf, fortgeschrittene Konsolenausgaben/eingaben | AlexanderK | seba(2010) | |
Buchhaltung | 6 | 3. VL | Lesen aus Dateien | reiner | AndyF (2010) | |
StringArraySortieren | 5 | 3. VL | Konsolparameter, Funktionspointer | reiner | martin (2010) | |
integral | 2 | 3. VL | Funktionspointer | reiner | TKroenert (2010) | |
forschleife | 3 | 4. Tut | Bug (zum Knobeln) | reiner | nion (2009), TKroenert (2010) | |
GDSL | 5-7 | 5. Tut | Anwendung der Generic Data Structures Library | martin | ||
Standard C Library | 3 | 5. Tut | Recherche in der Standard C Bibliothek | martin | ||
Tron | 7-9 | 5. Tut | SDL (Simple Directmedia Layer) kennen lernen, graphische Ausgabe | seba | ||
TicTacToe | 5-7 | 5. Tut | SDL (Simple Directmedia Layer) kennen lernen, graphische Ausgabe | Martin | sdyroff (2010) | |
ieee754 | 3 | 2. Tut | Katrin | |||
String-Konkatenation | 3 | 2. VL | Malloc, Umgang mit Zeichenketten | Andreas | ||
Autohaus | 3 | 2. Tut | Structs | Andreas |
Kleine und große Probleme
- Die Tubit-Accounts haben nicht /bin/bash als shell, so dass die Cursortasten nicht funktionieren. Workaround: als erstes Kommando 'bash' eingeben, man sieht dann auch in welchem Verzeichnis man gerade ist.
- wenn man nur den Promt 'bash-0.12' oder so erhält, also ohne das Verzeichnis in dem man ist, folgendes Kommando eingeben: export PS1='\u@\h:\w$ ' oder zum dauerhaften Speichern: echo "export PS1='\u@\h:\w$ '" >> ~/.bashrc
Musterlösungen
Die Lösungen zu den Aufgaben werden nach den jeweiligen Übungen hier veröffentlicht. Falls dies nicht geschieht, bitte den zuständigen Tutor fragen.