Sitzung: Jeden Freitag in der Vorlesungszeit ab 16 Uhr c. t. im MAR 0.005. In der vorlesungsfreien Zeit unregelmäßig (Jemensch da?). Macht mit!

C-Kurs/Übungsaufgaben: Unterschied zwischen den Versionen

K (Musterlösung)
(cleanup & musterlösungen)
Zeile 22: Zeile 22:
 
  | align="center" |1. VL
 
  | align="center" |1. VL
 
  | Konsole benutzen, Hello World
 
  | Konsole benutzen, Hello World
  | <!-- - -->
+
  | -
 
 
  
 
  |- bgcolor="#E8E8E8"
 
  |- bgcolor="#E8E8E8"
Zeile 30: Zeile 29:
 
  | align="center" |1. VL
 
  | align="center" |1. VL
 
  | Schleifen
 
  | Schleifen
  | <!-- - -->
+
  | -
 
 
  
 
  |- bgcolor="#F5F5F5"
 
  |- bgcolor="#F5F5F5"
Zeile 39: Zeile 37:
 
  | Schleifen, if-Bedingungen
 
  | Schleifen, if-Bedingungen
 
  | [[Ckurs/Pythagoras-Triplet/Musterlösung | Musterlösung]]
 
  | [[Ckurs/Pythagoras-Triplet/Musterlösung | Musterlösung]]
 
  
 
  |- bgcolor="#E8E8E8"
 
  |- bgcolor="#E8E8E8"
Zeile 47: Zeile 44:
 
  | Funktionen, Rekursion
 
  | Funktionen, Rekursion
 
  | [[Ckurs/Fibonacci-Folge/Musterlösung | Musterlösung]]
 
  | [[Ckurs/Fibonacci-Folge/Musterlösung | Musterlösung]]
 
  
 
  |- bgcolor="#F5F5F5"
 
  |- bgcolor="#F5F5F5"
Zeile 55: Zeile 51:
 
  | Kontrollstrukturen, Bitweise Operatoren
 
  | Kontrollstrukturen, Bitweise Operatoren
 
  | [[Ckurs/digitalesSchloesserKnacken/Musterlösung | Musterlösung]]
 
  | [[Ckurs/digitalesSchloesserKnacken/Musterlösung | Musterlösung]]
 
  
 
  |- bgcolor="#E8E8E8"
 
  |- bgcolor="#E8E8E8"
Zeile 63: Zeile 58:
 
  | Bekannte Operatoren wie + durch Funktionen succ und neg nachbilden
 
  | Bekannte Operatoren wie + durch Funktionen succ und neg nachbilden
 
  | [[Ckurs/Rekursives_arbeiten/Musterlösung | Musterlösung]]
 
  | [[Ckurs/Rekursives_arbeiten/Musterlösung | Musterlösung]]
 
  
 
  |- bgcolor="#F5F5F5"
 
  |- bgcolor="#F5F5F5"
Zeile 71: Zeile 65:
 
  | Operatoren
 
  | Operatoren
 
  | [[Ckurs/Base64/Musterlösung | Musterlösung]]
 
  | [[Ckurs/Base64/Musterlösung | Musterlösung]]
 
  
 
  |- bgcolor="#E8E8E8"
 
  |- bgcolor="#E8E8E8"
Zeile 79: Zeile 72:
 
  | Einlesen von Benutzereingaben, Ausgabe derselben
 
  | Einlesen von Benutzereingaben, Ausgabe derselben
 
  | [[Ckurs/EingabeAusgabe/Musterlösung | Musterlösung]]
 
  | [[Ckurs/EingabeAusgabe/Musterlösung | Musterlösung]]
 
  
 
  |- bgcolor="#F5F5F5"
 
  |- bgcolor="#F5F5F5"
Zeile 87: Zeile 79:
 
  | Eingabe+Ausgabe, Mathematische Operatoren
 
  | Eingabe+Ausgabe, Mathematische Operatoren
 
  | [[Ckurs/Taschenrechner/Musterlösung | Musterlösung]]
 
  | [[Ckurs/Taschenrechner/Musterlösung | Musterlösung]]
 
  
 
  |- bgcolor="#E8E8E8"
 
  |- bgcolor="#E8E8E8"
Zeile 95: Zeile 86:
 
  | Umgang mit mehreren verschachtelten Schleifen
 
  | Umgang mit mehreren verschachtelten Schleifen
 
  | [[Ckurs/VerschachtelteSchleifen/Musterlösung | Musterlösung]]
 
  | [[Ckurs/VerschachtelteSchleifen/Musterlösung | Musterlösung]]
 
  
 
  |- bgcolor="#F5F5F5"
 
  |- bgcolor="#F5F5F5"
Zeile 103: Zeile 93:
 
  | Anwenden von Fallunterscheidungen und Einlesen von Werten aus der Konsole
 
  | Anwenden von Fallunterscheidungen und Einlesen von Werten aus der Konsole
 
  | [[Ckurs/Glückspiel/Musterlösung | Musterlösung]]
 
  | [[Ckurs/Glückspiel/Musterlösung | Musterlösung]]
 
  
 
  |- bgcolor="#E8E8E8"
 
  |- bgcolor="#E8E8E8"
Zeile 111: Zeile 100:
 
  | Array, Dateien lesen
 
  | Array, Dateien lesen
 
  | [[Ckurs/Buchstaben_zählen/Musterlösung | Musterlösung]]
 
  | [[Ckurs/Buchstaben_zählen/Musterlösung | Musterlösung]]
 
  
 
  |- bgcolor="#E8E8E8"
 
  |- bgcolor="#E8E8E8"
Zeile 118: Zeile 106:
 
  | align="center" |1. Tut
 
  | align="center" |1. Tut
 
  | Einlesen von Benutzereingaben, Mathematikverständniss
 
  | Einlesen von Benutzereingaben, Mathematikverständniss
  | [[Ckurs/Wochentag/Musterlösung | Musterlösung]]
+
  | N/A
  
 
  |- bgcolor="#F5F5F5"
 
  |- bgcolor="#F5F5F5"
Zeile 132: Zeile 120:
 
  | align="center" |2. VL
 
  | align="center" |2. VL
 
  | Einfache Anwendung von &/*
 
  | Einfache Anwendung von &/*
  | <!-- [[Ckurs/Call by reference/Musterlösung | Musterlösung]] -->
+
  | [[Ckurs/Call by reference/Musterlösung | Musterlösung]]
  
 
  |- bgcolor="#F5F5F5"
 
  |- bgcolor="#F5F5F5"
Zeile 139: Zeile 127:
 
  | align="center" |2. VL
 
  | align="center" |2. VL
 
  | Original-Dokumentation anwenden (Opengroup, man pages), Pointer auf Pointer, Const correctness, Strings
 
  | Original-Dokumentation anwenden (Opengroup, man pages), Pointer auf Pointer, Const correctness, Strings
  | <!-- [[Ckurs/String to Double/Musterlösung | Musterlösung]] -->
+
  | [[Ckurs/String to Double/Musterlösung | Musterlösung]]
  
 
  |- bgcolor="#E8E8E8"
 
  |- bgcolor="#E8E8E8"
Zeile 146: Zeile 134:
 
  | align="center" |2. VL
 
  | align="center" |2. VL
 
  | Strings, Pointer-Arithmetik, Pointer auf Pointer, Refactoring
 
  | Strings, Pointer-Arithmetik, Pointer auf Pointer, Refactoring
  | <!-- [[Ckurs/Text processing/Musterlösung | Musterlösung]] -->
+
  | [[Ckurs/Text processing/Musterlösung | Musterlösung]]
  
 
  |- bgcolor="#F5F5F5"
 
  |- bgcolor="#F5F5F5"
Zeile 153: Zeile 141:
 
  | align="center" |2. VL
 
  | align="center" |2. VL
 
  | Pointer und Strings
 
  | Pointer und Strings
  | <!-- [[Ckurs/Palindrome/Musterlösung | Musterlösung]] -->
+
  | [[Ckurs/Palindrome/Musterlösung | Musterlösung]]
  
 
  |- bgcolor="#F5F5F5"
 
  |- bgcolor="#F5F5F5"
Zeile 160: Zeile 148:
 
  | align="center" |2. VL
 
  | align="center" |2. VL
 
  | Pointer und Arrays benutzen, generisches swap
 
  | Pointer und Arrays benutzen, generisches swap
  | <!-- [[Ckurs/(Pointer) Swapping/Musterlösung | Musterlösung]] -->
+
  | [[Ckurs/(Pointer) Swapping/Musterlösung | Musterlösung]]
  
 
  |- bgcolor="#E8E8E8"
 
  |- bgcolor="#E8E8E8"
Zeile 167: Zeile 155:
 
  | align="center" |2. VL
 
  | align="center" |2. VL
 
  | Mehrdimensionale Arrays, const correctness
 
  | Mehrdimensionale Arrays, const correctness
  | <!-- [[Ckurs/Matrizenmultiplikation/Musterlösung | Musterlösung]] -->
+
  | [[Ckurs/Matrizenmultiplikation/Musterlösung | Musterlösung]]
  
 
  |- bgcolor="#F5F5F5"
 
  |- bgcolor="#F5F5F5"
Zeile 174: Zeile 162:
 
  | align="center" |2. VL
 
  | align="center" |2. VL
 
  | Mathematische Rechenoperationen, Algorithmik
 
  | Mathematische Rechenoperationen, Algorithmik
  | <!-- [[Ckurs/DreiD/Musterlösung | Musterlösung]] -->
+
  | [[Ckurs/DreiD/Musterlösung | Musterlösung]]
  
 
  |- bgcolor="#E8E8E8"
 
  |- bgcolor="#E8E8E8"
Zeile 181: Zeile 169:
 
  | align="center" |2. VL
 
  | align="center" |2. VL
 
  | Einlesen von Benutzereingaben, Pointer und Pointerarithmetik
 
  | Einlesen von Benutzereingaben, Pointer und Pointerarithmetik
  | <!-- [[Ckurs/Arrayuebergabe/Musterlösung | Musterlösung]] -->
+
  | [[Ckurs/Arrayuebergabe/Musterlösung | Musterlösung]]
  
 
  |- bgcolor="#F5F5F5"
 
  |- bgcolor="#F5F5F5"
Zeile 188: Zeile 176:
 
  | align="center" |2. VL
 
  | align="center" |2. VL
 
  | struct, Pointer, Arrays
 
  | struct, Pointer, Arrays
  | <!-- [[Ckurs/Studentendatenbank/Musterlösung | Musterlösung]] -->
+
  | [[Ckurs/Studentendatenbank/Musterlösung | Musterlösung]]
  
 
  |- bgcolor="#E8E8E8"
 
  |- bgcolor="#E8E8E8"
Zeile 195: Zeile 183:
 
  | align="center" |2. VL
 
  | align="center" |2. VL
 
  | Structs, Unions, Pointer
 
  | Structs, Unions, Pointer
  | <!-- [[Ckurs/Punktstrukturen/ Musterlösung | Musterlösung]] -->
+
  | N/A
  
 
  |- bgcolor="#F5F5F5"
 
  |- bgcolor="#F5F5F5"
 
  | [[Ckurs/Sammelbestellung | Sammelbestellung]]
 
  | [[Ckurs/Sammelbestellung | Sammelbestellung]]
 
  | align="center" |2-5
 
  | align="center" |2-5
  | align="center" |2. VL
+
  | align="center" |3. VL
 
  | Listen, Pointer, Speicherverwaltung
 
  | Listen, Pointer, Speicherverwaltung
  | <!-- [[Ckurs/Sammelbestellung/Musterlösung | Musterlösung]] -->
+
  | [[Ckurs/Sammelbestellung/Musterlösung | Musterlösung]]
  
 
  |- bgcolor="#E8E8E8"
 
  |- bgcolor="#E8E8E8"
Zeile 209: Zeile 197:
 
  | align="center" |2. VL
 
  | align="center" |2. VL
 
  | Umgang mit Zeichenketten
 
  | Umgang mit Zeichenketten
  | <!-- [[Ckurs/Zahlen_sagen/Musterlösung | Musterlösung]] -->
+
  | [[Ckurs/Zahlen_sagen/Musterlösung | Musterlösung]]
  
 
  |- bgcolor="#F5F5F5"
 
  |- bgcolor="#F5F5F5"
Zeile 216: Zeile 204:
 
  | align="center" |3. Tut
 
  | align="center" |3. Tut
 
  | Arbeiten mit mehreren Quellcode-Dateien, Kompilieren und Linken, Header-Dateien und #include, debugging-Makro verwenden
 
  | Arbeiten mit mehreren Quellcode-Dateien, Kompilieren und Linken, Header-Dateien und #include, debugging-Makro verwenden
  | <!-- - -->
+
  | N/A
  
 
  |- bgcolor="#E8E8E8"
 
  |- bgcolor="#E8E8E8"
Zeile 251: Zeile 239:
 
  | align="center" |2. VL
 
  | align="center" |2. VL
 
  | Kleinere Codeschipsel mit kleinen Unsauberkeiten
 
  | Kleinere Codeschipsel mit kleinen Unsauberkeiten
  | <!-- [[Ckurs/Code Layout/Musterlösung | Musterlösung]] -->
+
  | [[Ckurs/Code Layout/Musterlösung | Musterlösung]]
  
 
  |- bgcolor="#E8E8E8"
 
  |- bgcolor="#E8E8E8"
Zeile 258: Zeile 246:
 
  | align="center" |2. VL
 
  | align="center" |2. VL
 
  | Wie verbessere ich den Quellcode eines Programmes.
 
  | Wie verbessere ich den Quellcode eines Programmes.
  | <!-- [[Ckurs/Refactoring/Musterlösung | Musterlösung]] -->
+
  | [[Ckurs/Refactoring/Musterlösung | Musterlösung]]
  
 
  |- bgcolor="#F5F5F5"
 
  |- bgcolor="#F5F5F5"
Zeile 265: Zeile 253:
 
  | align="center" |1. Tut
 
  | align="center" |1. Tut
 
  | Arbeiten mit Dateien, Kommandozeilenparameter
 
  | Arbeiten mit Dateien, Kommandozeilenparameter
  | <!-- [[Ckurs/Cat/Musterlösung | Musterlösung]] -->
+
  | [[Ckurs/Cat/Musterlösung | Musterlösung]]
  
 
  |- bgcolor="#E8E8E8"
 
  |- bgcolor="#E8E8E8"
Zeile 279: Zeile 267:
 
  | align="center" |2. VL
 
  | align="center" |2. VL
 
  | Lesen aus Dateien
 
  | Lesen aus Dateien
  | <!-- [[Ckurs/Buchhaltung/Musterlösung | Musterlösung]] -->
+
  | N/A
  
 
  |- bgcolor="#E8E8E8"
 
  |- bgcolor="#E8E8E8"
Zeile 286: Zeile 274:
 
  | align="center" |2. VL
 
  | align="center" |2. VL
 
  | Konsolparameter, Funktionspointer
 
  | Konsolparameter, Funktionspointer
  | <!-- [[Ckurs/StringArraySortieren/Musterlösung | Musterlösung]] -->
+
  | [[Ckurs/StringArraySortieren/Musterlösung | Musterlösung]]
  
 
  |- bgcolor="#F5F5F5"
 
  |- bgcolor="#F5F5F5"
Zeile 293: Zeile 281:
 
  | align="center" |2. VL
 
  | align="center" |2. VL
 
  | Funktionspointer
 
  | Funktionspointer
  | <!-- [[Ckurs/integral/Musterlösung | Musterlösung]] -->
+
  | [[Ckurs/integral/Musterlösung | Musterlösung]]
  
 
  |- bgcolor="#E8E8E8"
 
  |- bgcolor="#E8E8E8"
Zeile 335: Zeile 323:
 
  | align="center" |2. Tut
 
  | align="center" |2. Tut
 
  |  
 
  |  
  | <!-- [http://docs.freitagsrunde.org/Veranstaltungen/ckurs_2011/aufgaben/ieee754/ieee754_loesung.c Musterlösung] -->
+
  | [http://docs.freitagsrunde.org/Veranstaltungen/ckurs_2011/aufgaben/ieee754/ieee754_loesung.c Musterlösung]
  
 
  |- bgcolor="#E8E8E8"
 
  |- bgcolor="#E8E8E8"
Zeile 342: Zeile 330:
 
  | align="center" |3. VL
 
  | align="center" |3. VL
 
  | Malloc, Umgang mit Zeichenketten
 
  | Malloc, Umgang mit Zeichenketten
  | <!-- [Ckurs/concat/Musterloesung | Musterlösung]] -->
+
  | [[Ckurs/concat/Musterlösung | Musterlösung]]
  
 
  |- bgcolor="#F5F5F5"
 
  |- bgcolor="#F5F5F5"
Zeile 349: Zeile 337:
 
  | align="center" |2. Tut
 
  | align="center" |2. Tut
 
  | Structs
 
  | Structs
  | <!-- [[Ckurs/Autohaus/Musterloesung | Musterlösung]] -->
+
  | [[Ckurs/Autohaus/Musterlösung | Musterlösung]]
  
 
  |- bgcolor="#E8E8E8"
 
  |- bgcolor="#E8E8E8"
Zeile 356: Zeile 344:
 
  | align="center" |3. VL
 
  | align="center" |3. VL
 
  | Pointer, Arrays, Umgang mit Audiodaten
 
  | Pointer, Arrays, Umgang mit Audiodaten
  | <!-- [[Ckurs/DTMF-Encoder/Musterlösung | Musterlösung]] -->
+
  | [[Ckurs/DTMF-Encoder/Musterlösung | Musterlösung]]
 
|}
 
|}
  

Version vom 13. September 2012, 15:04 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.

Die Aufgaben

Aufgabe Schwierigkeit Vorwissen Lerneffekte Musterlösung


Von der Konsole zum HelloWorld 1 1. VL Konsole benutzen, Hello World -
Fakultät 2 1. VL Schleifen -
Pythagoras-Triplet 3 1. VL Schleifen, if-Bedingungen Musterlösung
Fibonacci-Folge 2 1. VL Funktionen, Rekursion Musterlösung
digitales Schloesser knacken 4 1. VL Kontrollstrukturen, Bitweise Operatoren Musterlösung
Rekursives Arbeiten 3-5 1. VL Bekannte Operatoren wie + durch Funktionen succ und neg nachbilden Musterlösung
Base64 6 1. VL Operatoren Musterlösung
Ein- und Ausgabe 1 1. Tut Einlesen von Benutzereingaben, Ausgabe derselben Musterlösung
Taschenrechner 3 1. Tut Eingabe+Ausgabe, Mathematische Operatoren Musterlösung
Verschachtelte Schleifen 3 1. Tut Umgang mit mehreren verschachtelten Schleifen Musterlösung
Glücksspiel 3 1. Tut Anwenden von Fallunterscheidungen und Einlesen von Werten aus der Konsole Musterlösung
Buchstaben zählen 4 1. Tut Array, Dateien lesen Musterlösung
Wochentagsrechnung 5 1. Tut Einlesen von Benutzereingaben, Mathematikverständniss N/A
Taschenrechner 2.0 8 1. Tut Knobeln, Komplexes Aufgaben lösen Musterlösung
Call by reference 4 2. VL Einfache Anwendung von &/* Musterlösung
String to Double 5 2. VL Original-Dokumentation anwenden (Opengroup, man pages), Pointer auf Pointer, Const correctness, Strings Musterlösung
Text processing 4, 6 2. VL Strings, Pointer-Arithmetik, Pointer auf Pointer, Refactoring Musterlösung
Palindrome 4 2. VL Pointer und Strings Musterlösung
(Pointer) Swapping 5 2. VL Pointer und Arrays benutzen, generisches swap Musterlösung
Matrizenmultiplikation 6 2. VL Mehrdimensionale Arrays, const correctness Musterlösung
3D mit C 6-9 2. VL Mathematische Rechenoperationen, Algorithmik Musterlösung
Arrayuebergabe 4/5 2. VL Einlesen von Benutzereingaben, Pointer und Pointerarithmetik Musterlösung
Studentendatenbank 4 2. VL struct, Pointer, Arrays Musterlösung
Punktstrukturen 2-3 2. VL Structs, Unions, Pointer N/A
Sammelbestellung 2-5 3. VL Listen, Pointer, Speicherverwaltung Musterlösung
Zahlen sagen 5 2. VL Umgang mit Zeichenketten Musterlösung
Compiler, Präprozessor, Header Files 3 3. Tut Arbeiten mit mehreren Quellcode-Dateien, Kompilieren und Linken, Header-Dateien und #include, debugging-Makro verwenden N/A
Bus Error 8 4. Tut Pointer, wie entsteht ein bus error
BubbleSort Debugging 5 4. Tut Debuggen eines Programmes mit gdb
Debugging 1-8 4. Tut Debuggen einer Anwendung nach Wahl
CKDU 3-10 2. VL Live-Coding-aufgabe dem CKurs 2010
Code Layout 3 2. VL Kleinere Codeschipsel mit kleinen Unsauberkeiten Musterlösung
Refactoring 5-9 2. VL Wie verbessere ich den Quellcode eines Programmes. Musterlösung
Cat 6 1. Tut Arbeiten mit Dateien, Kommandozeilenparameter Musterlösung
Pong 7 5. Tut allgemeiner Programmablauf, fortgeschrittene Konsolenausgaben/eingaben
Buchhaltung 6 2. VL Lesen aus Dateien N/A
StringArraySortieren 5 2. VL Konsolparameter, Funktionspointer Musterlösung
integral 2 2. VL Funktionspointer Musterlösung
forschleife 3 4. Tut Bug (zum Knobeln)
GDSL 5-7 5. Tut Anwendung der Generic Data Structures Library
Standard C Library 3 5. Tut Recherche in der Standard C Bibliothek
Tron 7-9 5. Tut SDL (Simple Directmedia Layer) kennen lernen, graphische Ausgabe
TicTacToe 5-7 5. Tut SDL (Simple Directmedia Layer) kennen lernen, graphische Ausgabe
ieee754 3 2. Tut Musterlösung
String-Konkatenation 3 3. VL Malloc, Umgang mit Zeichenketten Musterlösung
Autohaus 3 2. Tut Structs Musterlösung
DTMF-Encoder 8 3. VL Pointer, Arrays, Umgang mit Audiodaten Musterlösung

Schwierigkeitsgrade

  1. Reines Tutorial. Man muss nicht viel selbst denken
  2. ...
  3. Leichte Übungsaufgabe. Studies, die noch eher unsicher sind werden hier gut begleitet.
  4. ...
  5. Typische Aufgabe. Man muss den Kopf benutzen, bekommt an schwierigen Stellen aber Hilfestellungen.
  6. ...
  7. Herausfordernd, eher etwas für Studies die etwas fitter sind.
  8. ...
  9. Auch erfahrene Programmierer werden hier ein bis zwei Übungen beschäftigt sein

  10. Tja, die Idee war da. Wir finden sie auch gut, aber es könnte wirklich anstrengend werden.


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.