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

(Neue Aufgabe)
(farben!)
Zeile 21: Zeile 21:
 
== Die Aufgaben ==
 
== Die Aufgaben ==
  
{| class="wikitable sortable" border="0" cellpadding="4" cellspacing="2"
+
{| class="wikitable sortable" border="0" cellpadding="4" cellspacing="2"}
 +
 
 
  |- bgcolor="#D8D8D8"
 
  |- bgcolor="#D8D8D8"
 
  !Aufgabe
 
  !Aufgabe
Zeile 46: Zeile 47:
 
  | Daniel (2009),  
 
  | Daniel (2009),  
 
  |   
 
  |   
  |- bgcolor="#E8E8E8"
+
  |- bgcolor="#F5F5F5"
 
  | [[Ckurs2010/Pythagoras-Triplet | Pythagoras-Triplet]]
 
  | [[Ckurs2010/Pythagoras-Triplet | Pythagoras-Triplet]]
 
  | align="center" |2
 
  | align="center" |2
Zeile 54: Zeile 55:
 
  |  
 
  |  
 
  | [[Ckurs2010/Pythagoras-Triplet/Musterloesung | Pythagoras-Triplet]]
 
  | [[Ckurs2010/Pythagoras-Triplet/Musterloesung | Pythagoras-Triplet]]
  |- bgcolor="#F5F5F5"
+
  |- bgcolor="#E8E8E8"
 
  | [[Ckurs2009/Fibonacci-Folge|Fibonacci-Folge]]
 
  | [[Ckurs2009/Fibonacci-Folge|Fibonacci-Folge]]
 
  | align="center" |2
 
  | align="center" |2
Zeile 70: Zeile 71:
 
  | Eugen R. (2010)
 
  | Eugen R. (2010)
 
  | [[Ckurs2009/digitalesSchloesserKnacken/Musterlösung | digitales Schloesser knacken]]
 
  | [[Ckurs2009/digitalesSchloesserKnacken/Musterlösung | digitales Schloesser knacken]]
  |- bgcolor="#F5F5F5"
+
  |- bgcolor="#E8E8E8"
 
  | [[Ckurs2009/Rekursives_arbeiten|Rekursives Arbeiten]]
 
  | [[Ckurs2009/Rekursives_arbeiten|Rekursives Arbeiten]]
 
  | align="center" |3-5
 
  | align="center" |3-5
Zeile 150: Zeile 151:
 
  | Eugen R. (2010)
 
  | Eugen R. (2010)
 
  | vorhanden
 
  | vorhanden
  |- bgcolor="#F5F5F5"
+
  |- bgcolor="#E8E8E8"
 
  | [[Ckurs2009/Text processing | Text processing]]
 
  | [[Ckurs2009/Text processing | Text processing]]
 
  | align="center" |4, 6
 
  | align="center" |4, 6
Zeile 158: Zeile 159:
 
  | [[Benutzer:Mario|Mario]] (2009),  
 
  | [[Benutzer:Mario|Mario]] (2009),  
 
  | [[Ckurs2009/Text processing/Musterlösung | Text processing]]
 
  | [[Ckurs2009/Text processing/Musterlösung | Text processing]]
  |- bgcolor="#E8E8E8"
+
  |- bgcolor="#F5F5F5"
 
  | [[Ckurs2009/Palindrome | Palindrome]]
 
  | [[Ckurs2009/Palindrome | Palindrome]]
 
  | align="center" |4
 
  | align="center" |4
Zeile 166: Zeile 167:
 
  | nion (2009),  
 
  | nion (2009),  
 
  | [[Ckurs2009/Palindrome/Musterlösung | Palindrome ]]
 
  | [[Ckurs2009/Palindrome/Musterlösung | Palindrome ]]
  |- bgcolor="#F5F5F5"
+
  |- bgcolor="#E8E8E8"
 
  | [[Ckurs/Buchstaben_zählen | Buchstaben zählen]]
 
  | [[Ckurs/Buchstaben_zählen | Buchstaben zählen]]
 
  | align="center" |4
 
  | align="center" |4
Zeile 190: Zeile 191:
 
  | [[Benutzer:Mario|Mario]] (2009),  
 
  | [[Benutzer:Mario|Mario]] (2009),  
 
  | [[Ckurs2009/Matrizenmultiplikation/Musterlösung | Matrizenmultiplikation]]
 
  | [[Ckurs2009/Matrizenmultiplikation/Musterlösung | Matrizenmultiplikation]]
  |- bgcolor="#E8E8E8"
+
  |- bgcolor="#F5F5F5"
 
  | [[Ckurs/DreiD | 3D mit C]]
 
  | [[Ckurs/DreiD | 3D mit C]]
 
  | align="center" |6-9
 
  | align="center" |6-9
Zeile 198: Zeile 199:
 
  |  
 
  |  
 
  | vorhanden
 
  | vorhanden
  |- bgcolor="#F5F5F5"
+
  |- bgcolor="#E8E8E8"
 
  | [[Ckurs2009/Arrayuebergabe | Arrayuebergabe]]
 
  | [[Ckurs2009/Arrayuebergabe | Arrayuebergabe]]
 
  | align="center" |4/5
 
  | align="center" |4/5
Zeile 206: Zeile 207:
 
  | Martin K. (2009),  
 
  | Martin K. (2009),  
 
  | [[Ckurs2009/Arrayuebergabe/Musterlösung | Arrayuebergabe]]
 
  | [[Ckurs2009/Arrayuebergabe/Musterlösung | Arrayuebergabe]]
  |- bgcolor="#E8E8E8"
+
  |- bgcolor="#F5F5F5"
 
  | [[Ckurs2009/Studentendatenbank | Studentendatenbank]]
 
  | [[Ckurs2009/Studentendatenbank | Studentendatenbank]]
 
  | align="center" |4
 
  | align="center" |4
Zeile 214: Zeile 215:
 
  | Gabriel (2010)
 
  | Gabriel (2010)
 
  | [[Ckurs2009/Studentendatenbank/Musterlösung | Studentendatenbank]]
 
  | [[Ckurs2009/Studentendatenbank/Musterlösung | Studentendatenbank]]
  |- bgcolor="#A5A5A5"
+
  |- bgcolor="#E8E8E8"
 
  | [[Ckurs2010/Punktstrukturen| Punktstrukturen]]
 
  | [[Ckurs2010/Punktstrukturen| Punktstrukturen]]
 
  | align="center" |2-3
 
  | align="center" |2-3
Zeile 238: Zeile 239:
 
  | Paul B. (w.i.p.)
 
  | Paul B. (w.i.p.)
 
  | [[Ckurs2009/Zahlen_sagen/Musterlösung | Zahlen sagen]]
 
  | [[Ckurs2009/Zahlen_sagen/Musterlösung | Zahlen sagen]]
  |- bgcolor="#E8E8E8"
+
  |- bgcolor="#F5F5F5"
 
  | [[Ckurs2009/Compiler, Präprozessor, Header Files | Compiler, Präprozessor, Header Files]]
 
  | [[Ckurs2009/Compiler, Präprozessor, Header Files | Compiler, Präprozessor, Header Files]]
 
  | align="center" |3
 
  | align="center" |3
Zeile 246: Zeile 247:
 
  | AndyF (2010)
 
  | AndyF (2010)
 
  | [https://wiki.freitagsrunde.org/Ckurs2009/Vortrag05 siehe Folien]
 
  | [https://wiki.freitagsrunde.org/Ckurs2009/Vortrag05 siehe Folien]
  |- bgcolor="#F5F5F5"
+
  |- bgcolor="#E8E8E8"
 
  | [[Ckurs2009/Bus Error | Bus Error]]
 
  | [[Ckurs2009/Bus Error | Bus Error]]
 
  | align="center" |8
 
  | align="center" |8
Zeile 254: Zeile 255:
 
  | [[Benutzer:Mario|Mario]] (2010)
 
  | [[Benutzer:Mario|Mario]] (2010)
 
  | [[Ckurs2009/Bus Error/Musterlösung | Bus Error]]
 
  | [[Ckurs2009/Bus Error/Musterlösung | Bus Error]]
  |- bgcolor="#E8E8E8"
+
  |- bgcolor="#F5F5F5"
 
  | [[Ckurs2009/BubbleSortDebug | BubbleSort Debugging]]
 
  | [[Ckurs2009/BubbleSortDebug | BubbleSort Debugging]]
 
  | align="center" |5
 
  | align="center" |5
Zeile 262: Zeile 263:
 
  |
 
  |
 
  | [[Ckurs2009/BubbleSortDebug/Musterlösung | BubbleSort Debugging]]
 
  | [[Ckurs2009/BubbleSortDebug/Musterlösung | BubbleSort Debugging]]
  |- bgcolor="#F5F5F5"
+
  |- bgcolor="#E8E8E8"
 
  | [[Ckurs2009/Debug | Debugging]]
 
  | [[Ckurs2009/Debug | Debugging]]
 
  | align="center" |1-8
 
  | align="center" |1-8
Zeile 270: Zeile 271:
 
  |
 
  |
 
  |  
 
  |  
  |- bgcolor="#E8E8E8"
+
  |- bgcolor="#F5F5F5"
 
  | [[Ckurs2009/Code Layout | Code Layout]]
 
  | [[Ckurs2009/Code Layout | Code Layout]]
 
  | align="center" |3
 
  | align="center" |3
Zeile 278: Zeile 279:
 
  | [[Benutzer:Tkroenert|TKroenert]] (2010)
 
  | [[Benutzer:Tkroenert|TKroenert]] (2010)
 
  | [[Ckurs2009/Code Layout/Musterlösung | Code Layout]]
 
  | [[Ckurs2009/Code Layout/Musterlösung | Code Layout]]
  |- bgcolor="#F5F5F5"
+
  |- bgcolor="#E8E8E8"
 
  | [[Ckurs2009/Refactoring | Refactoring]]
 
  | [[Ckurs2009/Refactoring | Refactoring]]
 
  | align="center" |5-9
 
  | align="center" |5-9
Zeile 286: Zeile 287:
 
  |  
 
  |  
 
  | [[Ckurs2009/Refactoring/Musterlösung | Refactoring]]
 
  | [[Ckurs2009/Refactoring/Musterlösung | Refactoring]]
  |- bgcolor="#E8E8E8"
+
  |- bgcolor="#F5F5F5"
 
  | [[Ckurs2009/Cat | Cat]]
 
  | [[Ckurs2009/Cat | Cat]]
 
  | align="center" |6
 
  | align="center" |6
Zeile 294: Zeile 295:
 
  | sping (2009),  
 
  | sping (2009),  
 
  | vorhanden
 
  | vorhanden
  |- bgcolor="#F5F5F5"
+
  |- bgcolor="#E8E8E8"
 
  | [[Ckurs2009/Pong | Pong]]
 
  | [[Ckurs2009/Pong | Pong]]
 
  | align="center" |7
 
  | align="center" |7
Zeile 302: Zeile 303:
 
  |
 
  |
 
  | vorhanden  
 
  | vorhanden  
  |- bgcolor="#E8E8E8"
+
  |- bgcolor="#F5F5F5"
 
  | [[Ckurs2009/Buchhaltung | Buchhaltung]]
 
  | [[Ckurs2009/Buchhaltung | Buchhaltung]]
 
  | align="center" |6
 
  | align="center" |6
Zeile 310: Zeile 311:
 
  | AndyF (2010)
 
  | AndyF (2010)
 
  |  
 
  |  
  |- bgcolor="#F5F5F5"
+
  |- bgcolor="#E8E8E8"
 
  | [[Ckurs2009/StringArraySortieren | StringArraySortieren]]
 
  | [[Ckurs2009/StringArraySortieren | StringArraySortieren]]
 
  | align="center" |8
 
  | align="center" |8
Zeile 318: Zeile 319:
 
  |
 
  |
 
  | vorhanden
 
  | vorhanden
  |- bgcolor="#E8E8E8"
+
  |- bgcolor="#F5F5F5"
 
  | [[Ckurs/integral | integral]]
 
  | [[Ckurs/integral | integral]]
 
  | align="center" |2
 
  | align="center" |2
Zeile 326: Zeile 327:
 
  | [[Benutzer:Tkroenert|TKroenert]] (2010)
 
  | [[Benutzer:Tkroenert|TKroenert]] (2010)
 
  | [[Ckurs/integral/Musterlösung | Musterloesung]]
 
  | [[Ckurs/integral/Musterlösung | Musterloesung]]
  |- bgcolor="#F5F5F5"
+
  |- bgcolor="#E8E8E8"
 
  | [[Ckurs/forschleife | forschleife]]
 
  | [[Ckurs/forschleife | forschleife]]
 
  | align="center" |3
 
  | align="center" |3
Zeile 334: Zeile 335:
 
  | nion (2009), [[Benutzer:Tkroenert|TKroenert]] (2010)
 
  | nion (2009), [[Benutzer:Tkroenert|TKroenert]] (2010)
 
  | vorhanden
 
  | vorhanden
  |- bgcolor="#E8E8E8"
+
  |- bgcolor="#F5F5F5"
 
  | [[Ckurs/libgdsl | GDSL]]
 
  | [[Ckurs/libgdsl | GDSL]]
 
  | align="center" |5-7
 
  | align="center" |5-7
Zeile 342: Zeile 343:
 
  |  
 
  |  
 
  |  
 
  |  
  |- bgcolor="#F5F5F5"
+
  |- bgcolor="#E8E8E8"
 
  | [[Ckurs2009/StdLib | Standard C Library]]
 
  | [[Ckurs2009/StdLib | Standard C Library]]
 
  | align="center" |3
 
  | align="center" |3

Version vom 14. September 2010, 11:45 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.


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.

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 Gabriel P. 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 2. VL Einlesen von Benutzereingaben
Ausgabe derselben
Mario nion (2009), Ein- und Ausgabe
Taschenrechner 3 2. VL Eingabe+Ausgabe
Mathematische Operatoren
Mario TKroenert (2009), Taschenrechner
Verschachtelte Schleifen 3 2. VL Umgang mit mehreren verschachtelten Schleifen Daniel K. AlexanderK (2009),
Glücksspiel 3 2. VL Anwenden von Fallunterscheidungen und Einlesen von Werten aus der Konsole Daniel K. AlexanderK (2009), Glückspiel
Wochentagsrechnung 5 2. VL Einlesen von Benutzereingaben
Mathematikverständniss
Mario nion (Musterlösung noch nicht vorhanden) (2009),
Taschenrechner 2.0 8 2. VL Knobeln
Komplexes Aufgaben lösen
Mario Martin K. (2009), Taschenrechner 2.0
Call by reference 4 3. VL Einfache Anwendung von &/* sping nion (2009), 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
Text processing 4, 6 3. VL Strings
Pointer-Arithmetik
Pointer auf Pointer
Refactoring
sping Mario (2009), Text processing
Palindrome 4 3. VL Pointer und Strings Daniel K. nion (2009), Palindrome
Buchstaben zählen 4 3. VL Array, Dateien lesen Alex K. Gabriel (2010) vorhanden
(Pointer) Swapping 5 3. VL Pointer und Arrays benutzen, generisches swap Katrin Katrin (2010, wird nochmal überarbeitet bzw. mit mehr erklärendem Text versehen) (Pointer) Swapping
Matrizenmultiplikation 6 3. VL Mehrdimensionale Arrays
const correctness
sping Mario (2009), Matrizenmultiplikation
3D mit C 6-9 3. VL Mathematische Rechenoperationen, Algorithmik AndreasF vorhanden
Arrayuebergabe 4/5 4. VL Einlesen von Benutzereingaben
Pointer und Pointerarithmetik
nion Martin K. (2009), Arrayuebergabe
Studentendatenbank 4 4. VL struct, Pointer, Arrays AlexanderK Gabriel (2010) Studentendatenbank
Punktstrukturen 2-3 4. VL Structs, Unions, Pointer Florian (2010) - -
Sammelbestellung 2-5 4. VL Listen, Pointer, Speicherverwaltung Florian Mario (2009), Sammelbestellung
Zahlen sagen 5 4. VL Umgang mit Zeichenketten Martin K. Paul B. (w.i.p.) Zahlen sagen
Compiler, Präprozessor, Header Files 3 5. VL Arbeiten mit mehreren Quellcode-Dateien, Kompilieren und Linken, Header-Dateien und #include, debugging-Makro verwenden Katrin AndyF (2010) siehe Folien
Bus Error 8 5. VL Pointer, wie entsteht ein bus error Katrin Mario (2010) Bus Error
BubbleSort Debugging 5 6. VL Debuggen eines Programmes mit gdb aeichner BubbleSort Debugging
Debugging 1-8 6. VL Debuggen einer Anwendung nach Wahl aeichner
Code Layout 3 7. VL Kleinere Codeschipsel mit kleinen Unsauberkeiten Daniel TKroenert (2010) Code Layout
Refactoring 5-9 7. VL Wie verbessere ich den Quellcode eines Programmes. Daniel Refactoring
Cat 6 2. VL Arbeiten mit Dateien
Kommandozeilenparameter
nion sping (2009), vorhanden
Pong 7 9.VL (eigentlich 2.VL) allgemeiner Programmablauf, fortgeschrittene Konsolenausgaben/eingaben AlexanderK vorhanden
Buchhaltung 6 5.VL Lesen aus Dateien reiner AndyF (2010)
StringArraySortieren 8 3. VL Konsolparameter, Funktionspointer, stdlib reiner vorhanden
integral 2 3. VL Funktionspointer reiner TKroenert (2010) Musterloesung
forschleife 3 6. VL Bug (zum Knobeln) reiner nion (2009), TKroenert (2010) vorhanden
GDSL 5-7 9. VL Anwendung der Generic Data Structures Library martin
Standard C Library 3 9. VL Recherche in der Standard C Bibliothek martin

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.

Links