You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

022 Schleifen.ipynb 6.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260
  1. {
  2. "cells": [
  3. {
  4. "cell_type": "markdown",
  5. "metadata": {
  6. "pycharm": {
  7. "name": "#%% md\n"
  8. },
  9. "slideshow": {
  10. "slide_type": "slide"
  11. }
  12. },
  13. "source": [
  14. "# Software Entwicklung \n",
  15. "\n",
  16. "## Kapitel 2: Kontrollfluss"
  17. ]
  18. },
  19. {
  20. "cell_type": "markdown",
  21. "metadata": {
  22. "pycharm": {
  23. "name": "#%% md\n"
  24. },
  25. "slideshow": {
  26. "slide_type": "slide"
  27. }
  28. },
  29. "source": [
  30. "### 2.6 Schleife \n",
  31. "\n",
  32. "Häufig möchte man eine oder mehrere Anweisungen wiederholen, solange eine *Laufbedingung* erfüllt ist.\n",
  33. "Ein solcher Kontrollfluss wird auch als *Schleife* bezeichnet. Sofern die Bedingung geprüft wird, bevor\n",
  34. "die zu wiederholende Anweisung ausgeführt wird, spricht man von einer *kopfgesteuerten Schleife*.\n",
  35. "Wird erst nach der Ausführung überprüft, ob eine Wiederholung stattfinden soll, so handelt es\n",
  36. "sich um eine *fußgesteuerte Schleife*.\n",
  37. "\n",
  38. "![kopfgesteuerte Schleife](../img/SchleifeKopf.png \"Kopfgesteuerte Schleife\") "
  39. ]
  40. },
  41. {
  42. "cell_type": "markdown",
  43. "metadata": {
  44. "pycharm": {
  45. "name": "#%% md\n"
  46. },
  47. "slideshow": {
  48. "slide_type": "slide"
  49. }
  50. },
  51. "source": [
  52. "Mit dem Schlüsselwort <code>while</code> wird in Python eine kopfgesteuerte Schleife begonnen. Die Laufbedingung\n",
  53. "folgt unmittelbar danach abgeschlossen mit einem Doppelpunkt. Die zu wiederholenden Anweisungen werden\n",
  54. "wieder als eingerückter Block angegeben. Diesen Block nennt man auch *Schleifenrumpf*."
  55. ]
  56. },
  57. {
  58. "cell_type": "code",
  59. "execution_count": null,
  60. "metadata": {
  61. "pycharm": {
  62. "is_executing": false,
  63. "name": "#%%\n"
  64. }
  65. },
  66. "outputs": [],
  67. "source": [
  68. "a = 1\n",
  69. "\n",
  70. "while a < 10:\n",
  71. " print(a)\n",
  72. " a = a + 1\n",
  73. " \n",
  74. "print(\"Fertig\")"
  75. ]
  76. },
  77. {
  78. "cell_type": "markdown",
  79. "metadata": {
  80. "slideshow": {
  81. "slide_type": "slide"
  82. }
  83. },
  84. "source": [
  85. "Eine Schleife kann jederzeit abgebrochen werden, wenn im Schleifenrumpf das Schlüsselwort <code>break</code> \n",
  86. "auftaucht. Die Schleife wird dann sofort verlassen und die Ausführung mit dem nächsten Befehl nach dem Schleifenrumpf\n",
  87. "fortgesetzt. Aufgrund der besseren Lesbarkeit sollte <code>break</code> eher sparsam eingesetzt werden."
  88. ]
  89. },
  90. {
  91. "cell_type": "code",
  92. "execution_count": null,
  93. "metadata": {
  94. "pycharm": {
  95. "is_executing": false,
  96. "name": "#%%\n"
  97. }
  98. },
  99. "outputs": [],
  100. "source": [
  101. "a = 1\n",
  102. "\n",
  103. "while a < 10:\n",
  104. " print(a)\n",
  105. " if a == 5:\n",
  106. " break\n",
  107. " a = a + 1\n",
  108. "\n",
  109. "print(\"Fertig\", a)"
  110. ]
  111. },
  112. {
  113. "cell_type": "markdown",
  114. "metadata": {
  115. "slideshow": {
  116. "slide_type": "slide"
  117. }
  118. },
  119. "source": [
  120. "In Python gibt es zunächst einmal nur kopfgesteuerte Schleifen, jedoch können fußgesteuerte Schleifen\n",
  121. "recht einfach nachgebaut werden. Auch hier gilt wieder der Verweis auf eine bessere Lesbarkeit durch einen sparsamen Einsatz von <code>break</code>. Endlosschleifen sollten generell vermieden werden."
  122. ]
  123. },
  124. {
  125. "cell_type": "code",
  126. "execution_count": null,
  127. "metadata": {
  128. "pycharm": {
  129. "is_executing": false,
  130. "name": "#%%\n"
  131. }
  132. },
  133. "outputs": [],
  134. "source": [
  135. "a = 1\n",
  136. "\n",
  137. "while True:\n",
  138. " print(a)\n",
  139. " a = a + 1\n",
  140. " if a >= 6:\n",
  141. " break\n",
  142. "\n",
  143. "print(\"Fertig\")"
  144. ]
  145. },
  146. {
  147. "cell_type": "markdown",
  148. "metadata": {
  149. "slideshow": {
  150. "slide_type": "slide"
  151. }
  152. },
  153. "source": [
  154. "Neben dem vollständigen Schleifenabbruch mit <code>break</code> kann mittels <code>continue</code> auch nur der \n",
  155. "aktuelle Schleifendurchlauf abgebrochen werden. Aufgrund besserer Lesbarkeit sollte man sich aber immer die Frage stellen, ob sich ein <code>continue</code> nicht auch vermeiden lässt, z.B. durch entsprechende bedingte Ausführungen."
  156. ]
  157. },
  158. {
  159. "cell_type": "code",
  160. "execution_count": null,
  161. "metadata": {
  162. "pycharm": {
  163. "is_executing": false,
  164. "name": "#%%\n"
  165. }
  166. },
  167. "outputs": [],
  168. "source": [
  169. "a = 0\n",
  170. "\n",
  171. "while a < 10:\n",
  172. " a = a + 1\n",
  173. " if a % 2 != 0:\n",
  174. " continue\n",
  175. " print(a)\n",
  176. "\n",
  177. "print(\"Fertig\")"
  178. ]
  179. },
  180. {
  181. "cell_type": "markdown",
  182. "metadata": {
  183. "slideshow": {
  184. "slide_type": "slide"
  185. }
  186. },
  187. "source": [
  188. "Eine eher selten anzutreffende Variante ist die Verwendung eines optionalen <code>else</code> nach einer \n",
  189. "<code>while</code>-Schleife. Der <code>else</code>-Zweig wird dann ausgeführt, wenn die Laufbedingung \n",
  190. "nicht erfüllt ist *und* die Schleife nicht mit <code>break</code> verlassen wird. "
  191. ]
  192. },
  193. {
  194. "cell_type": "code",
  195. "execution_count": null,
  196. "metadata": {
  197. "pycharm": {
  198. "is_executing": false,
  199. "name": "#%%\n"
  200. }
  201. },
  202. "outputs": [],
  203. "source": [
  204. "a = 5\n",
  205. "\n",
  206. "while a > 0:\n",
  207. " print(a)\n",
  208. " if a < -1:\n",
  209. " break\n",
  210. " a = a - 1\n",
  211. "else:\n",
  212. " print(\"Else!\")\n",
  213. "\n",
  214. "print(\"Fertig\")"
  215. ]
  216. },
  217. {
  218. "cell_type": "markdown",
  219. "metadata": {
  220. "slideshow": {
  221. "slide_type": "slide"
  222. }
  223. },
  224. "source": [
  225. "Python bietet zudem eine <code>for</code>-Schleife an, mit der speziell Listen bzw. iterierbare Konstrukte durchlaufen werden können. Wir werden diese im Zusammenhang mit Listen in einem späteren Kapitel genauer betrachten."
  226. ]
  227. }
  228. ],
  229. "metadata": {
  230. "celltoolbar": "Slideshow",
  231. "kernelspec": {
  232. "display_name": "Python 3 (ipykernel)",
  233. "language": "python",
  234. "name": "python3"
  235. },
  236. "language_info": {
  237. "codemirror_mode": {
  238. "name": "ipython",
  239. "version": 3
  240. },
  241. "file_extension": ".py",
  242. "mimetype": "text/x-python",
  243. "name": "python",
  244. "nbconvert_exporter": "python",
  245. "pygments_lexer": "ipython3",
  246. "version": "3.9.9"
  247. },
  248. "pycharm": {
  249. "stem_cell": {
  250. "cell_type": "raw",
  251. "metadata": {
  252. "collapsed": false
  253. },
  254. "source": []
  255. }
  256. }
  257. },
  258. "nbformat": 4,
  259. "nbformat_minor": 1
  260. }