himynameis Geschrieben 31. März 2018 Geschrieben 31. März 2018 Hallo Zusammen. Ich hatte so meine Schwierigkeiten mit der folgenden Aufgabe: Erstes Problem: Auf der Folgeseite schreibt die IHK dann folgendes: Das stimmt doch bereits nicht, übergeben wird das zweidimensionale Array prozente, und zurückgegeben werden soll das eindimensionale Array sortProzente, oder sehe ich das falsch? Nun gut, ich habe dann meine Lösung ausgearbeitet, die allerdings als Sortieralgorithmus BubbleSort verwendet, da mich die Vorgabe der IHK stark an diesen erinnert hat. Ich hoffe das wäre dann auch das, was die IHK durchgehen lässt, ohne Punktabzug...? Ich poste folgend noch meinen Lösungsansatz, und wäre froh wenn Ihr kommentieren würdet, ob das soweit in Ordnung geht, ich bin mir nämlich ohnehin recht unsicher was Pseudocode angeht.. Das ganze kommt mir auch etwas mager vor, für 25 Punkte, hab ich was übersehen? sortProzente(prozent: zweidimensionales Array von double): eindimensionales Array von double Erstelle Array sortProzente[][] FÜR (int i = 0; i <= Länge prozente -1; i++) sortProzente = [i][prozente[i][1]] ENDE FÜR i FÜR (int j = Länge sortProzente -1; j > 1; j--) FÜR (int k = 0; k > j-1; k++) WENN sortProzente[k][1] > sortProzente[k + 1][1] DANN string temp = sortProzente[k][1] sortProzente[k][1] = sortProzente[k + 1][1] sortProzente[k + 1][1] = temp ENDE WENN ENDE FÜR k ENDE FÜR j return sortProzente Zitieren
ulfRadio Geschrieben 31. März 2018 Geschrieben 31. März 2018 So wie ich die Aufgabe verstanden habe, bekommt die Methode ein eindimensionales Array übergeben. Es sind nur die Prozentwerte in dem Array gespeichert. Zu jedem Prozentwert gibt es natürlich einen Index. Am Index O ist der Wert 38 hinterlegt. Index 3 hat 31. Und prozent[2] = 30 usw. Die Aufgabe soll nun sein, dass du das Array sortierst und der Index aus dem eindimensionalen Array mit dem prozentualen Wert gespeichert wird. Also sortProzente[0][0] = 4 und sortProzente[0][1] = 25 usw Deine Lösung finde ich sehr gut. Das einzige was ich ändern würde, wäre in der ersten Schleife in der das sortProzente gefüllt wird beide Spalten zu befüllen. sortProzente[i][0] = i sortProzente[i][1] = prozente[i] und in der Bedingung noch eine zusätzliche temporäre Variable für den Index anlegen. tempIndex = sortProzente[k][0] sortProzente[k][0] = sortProzente[k+1][0] sortProzente[k+1][0] = tempIndex Zitieren
himynameis Geschrieben 31. März 2018 Autor Geschrieben 31. März 2018 Danke @ulfRadio für Deine Antwort. Du hast recht, es soll ja ein zweidimensionales Array zurückgegeben werden. Mein Fehler. Das Befüllen des Arrays ist so wie Du es beschrieben hast auch korrekt. Ich bin davon ausgegangen, das die Indizes automatisch gesetzt werden.. Das mit der temporären Variable für den Index verstehe ich allerdings nicht so genau..ich mache dort einen Dreieckstausch, was anderes machst Du doch auch nicht? Zitieren
ulfRadio Geschrieben 31. März 2018 Geschrieben 31. März 2018 Wenn nur sortProzent[k][1] getauscht wird, bleibt der Index. Das Ergebnis ist dann sortProzente[0][0] = 0 ist (statt 4) und sortProzente[0][1] = 25. Deswegen die zweite temporäre Variable um im Dreieckstausch auch die erste Spalte zu tauschen. Der komplette Code in der Bedingung wäre dann: tempIndex = sortProzente[k][0] temp = sortProzente[k][1] sortProzente[k][0] = sortProzente[k+1][0] sortProzente[k][1] = sortProzente[k + 1][1] sortProzente[k+1][0] = tempIndex sortProzente[k + 1][1] = temp himynameis reagierte darauf 1 Zitieren
Empfohlene Beiträge
Dein Kommentar
Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.