From 43a8a79a3e60754b678a6b0be443d0ce9a5546fc Mon Sep 17 00:00:00 2001 From: Xanthron Writer Date: Mon, 29 May 2023 13:15:58 +0200 Subject: [PATCH] =?UTF-8?q?Weiter=20Aufgabe=20f=C3=BCr=20=C3=9Cbung=20Schl?= =?UTF-8?q?eifen?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Ich habe eine weitere Aufgabe zum Verstehen der Schleifen erstellt, die auf #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. --- .../02_python/05_schleifen/schleifen.ipynb | 110 +++++++++++++++++- 1 file changed, 109 insertions(+), 1 deletion(-) diff --git a/book/content/Exercises/02_python/05_schleifen/schleifen.ipynb b/book/content/Exercises/02_python/05_schleifen/schleifen.ipynb index b0b4b320..cce3f83d 100644 --- a/book/content/Exercises/02_python/05_schleifen/schleifen.ipynb +++ b/book/content/Exercises/02_python/05_schleifen/schleifen.ipynb @@ -1,6 +1,7 @@ { "cells": [ { + "attachments": {}, "cell_type": "markdown", "metadata": { "tags": [ @@ -24,6 +25,7 @@ ] }, { + "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ @@ -31,6 +33,7 @@ ] }, { + "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ @@ -38,6 +41,7 @@ ] }, { + "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ @@ -45,6 +49,7 @@ ] }, { + "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ @@ -56,6 +61,7 @@ ] }, { + "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ @@ -63,6 +69,7 @@ ] }, { + "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ @@ -70,6 +77,7 @@ ] }, { + "attachments": {}, "cell_type": "markdown", "metadata": { "tags": [ @@ -180,6 +188,7 @@ ] }, { + "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ @@ -187,6 +196,7 @@ ] }, { + "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ @@ -198,6 +208,7 @@ ] }, { + "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ @@ -205,6 +216,7 @@ ] }, { + "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ @@ -257,6 +269,7 @@ ] }, { + "attachments": {}, "cell_type": "markdown", "metadata": { "tags": [ @@ -320,6 +333,101 @@ " ms = v * 1000 / 3600\n", " print(v, '\\t', ms)" ] + }, + { + "attachments": {}, + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Aufgabenteil C\n", + "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", + "\n", + "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**." + ] + }, + { + "attachments": {}, + "cell_type": "markdown", + "metadata": {}, + "source": [ + "### Lösungsvorschlag" + ] + }, + { + "cell_type": "code", + "execution_count": 36, + "metadata": { + "tags": [ + "loesung", + "hide-cell" + ] + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "[0, 1, 2, 3, 7, 8, 9, 10, 14, 15, 16, 17, 21, 22, 23, 24, 28, 29]\n" + ] + } + ], + "source": [ + "N = 30\n", + "z1 = 4\n", + "z2 = 3\n", + "liste = []\n", + "\n", + "for z in range(z1):\n", + " liste += list(range(z, N, z1 + z2))\n", + "\n", + "liste.sort()\n", + "print(liste)" + ] + }, + { + "attachments": {}, + "cell_type": "markdown", + "metadata": {}, + "source": [ + "Um den Umgang mit Schleifen weiter zu festigen, soll die obrige Liste ohne das Sortieren am Ende erstellt werden.\n", + ":::::{tip}\n", + "::::{toggle}\n", + "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", + ":::{toggle}\n", + "Entfernen Sie mit einer `while`-Schleife die Überschüssigen Elemente\n", + ":::\n", + "::::\n", + ":::::" + ] + }, + { + "cell_type": "code", + "execution_count": 37, + "metadata": { + "tags": [ + "loesung", + "hide-cell" + ] + }, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "[0, 1, 2, 3, 7, 8, 9, 10, 14, 15, 16, 17, 21, 22, 23, 24, 28, 29, 30, 31]\n" + ] + } + ], + "source": [ + "liste = []\n", + "for i in range(0, N, z1 + z2):\n", + " for j in range(0, z1):\n", + " liste.append(i+j)\n", + "\n", + "while liste[-1] >= N:\n", + " liste.pop()\n", + "print(liste)" + ] } ], "metadata": { @@ -339,7 +447,7 @@ "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", - "version": "3.8.5" + "version": "3.10.10" } }, "nbformat": 4,