Skip to content

Commit 43a8a79

Browse files
Weiter Aufgabe für Übung Schleifen
Ich habe eine weitere Aufgabe zum Verstehen der Schleifen erstellt, die auf FireDynamics#26 basiert. Sie Zeigt auf, dass es für eine Lösung mehrere Wege gibt und wie diese mit neuen Tools erreicht werden können.
1 parent e72ac74 commit 43a8a79

File tree

1 file changed

+109
-1
lines changed

1 file changed

+109
-1
lines changed

book/content/Exercises/02_python/05_schleifen/schleifen.ipynb

Lines changed: 109 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,7 @@
11
{
22
"cells": [
33
{
4+
"attachments": {},
45
"cell_type": "markdown",
56
"metadata": {
67
"tags": [
@@ -24,27 +25,31 @@
2425
]
2526
},
2627
{
28+
"attachments": {},
2729
"cell_type": "markdown",
2830
"metadata": {},
2931
"source": [
3032
"# Anwendung von Schleifen"
3133
]
3234
},
3335
{
36+
"attachments": {},
3437
"cell_type": "markdown",
3538
"metadata": {},
3639
"source": [
3740
"In dieser Aufgabe wird die Verwendung von Schleifen anhand der Summation von ganzen Zahlen und in einer Umrechnungstabelle geübt."
3841
]
3942
},
4043
{
44+
"attachments": {},
4145
"cell_type": "markdown",
4246
"metadata": {},
4347
"source": [
4448
"## Aufgabenteil A"
4549
]
4650
},
4751
{
52+
"attachments": {},
4853
"cell_type": "markdown",
4954
"metadata": {},
5055
"source": [
@@ -56,20 +61,23 @@
5661
]
5762
},
5863
{
64+
"attachments": {},
5965
"cell_type": "markdown",
6066
"metadata": {},
6167
"source": [
6268
"### Lösungshinweis"
6369
]
6470
},
6571
{
72+
"attachments": {},
6673
"cell_type": "markdown",
6774
"metadata": {},
6875
"source": [
6976
"Für $\\sf N=100$ lautet das Ergebnis 5050. "
7077
]
7178
},
7279
{
80+
"attachments": {},
7381
"cell_type": "markdown",
7482
"metadata": {
7583
"tags": [
@@ -180,13 +188,15 @@
180188
]
181189
},
182190
{
191+
"attachments": {},
183192
"cell_type": "markdown",
184193
"metadata": {},
185194
"source": [
186195
"## Aufgabenteil B"
187196
]
188197
},
189198
{
199+
"attachments": {},
190200
"cell_type": "markdown",
191201
"metadata": {},
192202
"source": [
@@ -198,13 +208,15 @@
198208
]
199209
},
200210
{
211+
"attachments": {},
201212
"cell_type": "markdown",
202213
"metadata": {},
203214
"source": [
204215
"### Lösungshinweis"
205216
]
206217
},
207218
{
219+
"attachments": {},
208220
"cell_type": "markdown",
209221
"metadata": {},
210222
"source": [
@@ -257,6 +269,7 @@
257269
]
258270
},
259271
{
272+
"attachments": {},
260273
"cell_type": "markdown",
261274
"metadata": {
262275
"tags": [
@@ -320,6 +333,101 @@
320333
" ms = v * 1000 / 3600\n",
321334
" print(v, '\\t', ms)"
322335
]
336+
},
337+
{
338+
"attachments": {},
339+
"cell_type": "markdown",
340+
"metadata": {},
341+
"source": [
342+
"## Aufgabenteil C\n",
343+
"In der Vorherigen Übung sollte in einer Aufgabe eine Liste mit einem bestimmten Muster erstellt werden. Mit dem neu erlernten Konzept von schleifen, ist es nun möglich durch das verändern von zwei Variablen jedes mögliche Muster mit **N** Zahlen nach gleichem Prinzip zu erstellen.\n",
344+
"\n",
345+
"Schreiben Sie ein Skript, das eine Liste mit Zahlen von 0 bis **N** ausgibt. Jedoch sollen nur Zahlen in einem bestimmten Muster in der Liste vorhanden sein. **z1** zahlen hinzufügen, danach **z2** Zahlen überspringen, danach wieder **z1** einfügen Zahlen, um darauf die nächsten **z2** wieder zu überspringen, usw. bis zur Zahl **N**."
346+
]
347+
},
348+
{
349+
"attachments": {},
350+
"cell_type": "markdown",
351+
"metadata": {},
352+
"source": [
353+
"### Lösungsvorschlag"
354+
]
355+
},
356+
{
357+
"cell_type": "code",
358+
"execution_count": 36,
359+
"metadata": {
360+
"tags": [
361+
"loesung",
362+
"hide-cell"
363+
]
364+
},
365+
"outputs": [
366+
{
367+
"name": "stdout",
368+
"output_type": "stream",
369+
"text": [
370+
"[0, 1, 2, 3, 7, 8, 9, 10, 14, 15, 16, 17, 21, 22, 23, 24, 28, 29]\n"
371+
]
372+
}
373+
],
374+
"source": [
375+
"N = 30\n",
376+
"z1 = 4\n",
377+
"z2 = 3\n",
378+
"liste = []\n",
379+
"\n",
380+
"for z in range(z1):\n",
381+
" liste += list(range(z, N, z1 + z2))\n",
382+
"\n",
383+
"liste.sort()\n",
384+
"print(liste)"
385+
]
386+
},
387+
{
388+
"attachments": {},
389+
"cell_type": "markdown",
390+
"metadata": {},
391+
"source": [
392+
"Um den Umgang mit Schleifen weiter zu festigen, soll die obrige Liste ohne das Sortieren am Ende erstellt werden.\n",
393+
":::::{tip}\n",
394+
"::::{toggle}\n",
395+
"Nutzen Sie eine `for`-Schleife um Elemente in eine Liste einzufügen. Was passiert auf diese Weise jedoch bei `(N-1) % (z1 + z2) < z2` und welche maßnahme muss getroffen werden?\n",
396+
":::{toggle}\n",
397+
"Entfernen Sie mit einer `while`-Schleife die Überschüssigen Elemente\n",
398+
":::\n",
399+
"::::\n",
400+
":::::"
401+
]
402+
},
403+
{
404+
"cell_type": "code",
405+
"execution_count": 37,
406+
"metadata": {
407+
"tags": [
408+
"loesung",
409+
"hide-cell"
410+
]
411+
},
412+
"outputs": [
413+
{
414+
"name": "stdout",
415+
"output_type": "stream",
416+
"text": [
417+
"[0, 1, 2, 3, 7, 8, 9, 10, 14, 15, 16, 17, 21, 22, 23, 24, 28, 29, 30, 31]\n"
418+
]
419+
}
420+
],
421+
"source": [
422+
"liste = []\n",
423+
"for i in range(0, N, z1 + z2):\n",
424+
" for j in range(0, z1):\n",
425+
" liste.append(i+j)\n",
426+
"\n",
427+
"while liste[-1] >= N:\n",
428+
" liste.pop()\n",
429+
"print(liste)"
430+
]
323431
}
324432
],
325433
"metadata": {
@@ -339,7 +447,7 @@
339447
"name": "python",
340448
"nbconvert_exporter": "python",
341449
"pygments_lexer": "ipython3",
342-
"version": "3.8.5"
450+
"version": "3.10.10"
343451
}
344452
},
345453
"nbformat": 4,

0 commit comments

Comments
 (0)