Python :: Aufgabe #314 :: Lösung #2
5 Lösungen

#314
Iteriertes Querprodukt
Anfänger - Python
von JKooP
- 24.01.2021 um 16:44 Uhr
Das Querprodukt einer Zahl ähnelt der Berechnung der Quersumme,
nur dass die Ziffern nicht addiert, sondern miteinander multipliziert werden.
3784 => 3 * 7 * 8 * 4 = 672
Nun soll aus dem Ergebnis wiederum das Querprodukt berechnet werden.
672 => 6 * 7 * 2 = 84
Und immer so weiter, bis nur noch eine Ziffer übrigbleibt.
84 => 8 * 4 = 32
32 => 3 * 2 = 6
Die Ziffer, die am Ende übrigbleibt, nennt man „multiplikative Ziffernwurzel“.
Die Anzahl der Schritte (Iterationen) wird als "Beharrlichkeit" bezeichnet.
Schreibe ein Programm, mit dem es möglich ist, sowohl die Beharrlichkeit als auch die multiplikative Ziffernwurzel einer beliebigen Integer- Zahl auszugeben.
Eine ausführliche Beschreibung findet man hier.
Viel Spaß
nur dass die Ziffern nicht addiert, sondern miteinander multipliziert werden.
3784 => 3 * 7 * 8 * 4 = 672
Nun soll aus dem Ergebnis wiederum das Querprodukt berechnet werden.
672 => 6 * 7 * 2 = 84
Und immer so weiter, bis nur noch eine Ziffer übrigbleibt.
84 => 8 * 4 = 32
32 => 3 * 2 = 6
Die Ziffer, die am Ende übrigbleibt, nennt man „multiplikative Ziffernwurzel“.
Die Anzahl der Schritte (Iterationen) wird als "Beharrlichkeit" bezeichnet.
Schreibe ein Programm, mit dem es möglich ist, sowohl die Beharrlichkeit als auch die multiplikative Ziffernwurzel einer beliebigen Integer- Zahl auszugeben.
Eine ausführliche Beschreibung findet man hier.
Viel Spaß
#2

von vMaex (540 Punkte)
- 11.02.2021 um 10:17 Uhr

#Querprodukt zahl = 3784 liste = [] n_zahl = 1 counter = 0 for x in str(zahl): liste.append(int(x)) while len(liste) > 1: for x in liste: n_zahl *= x liste.clear() for x in str(n_zahl): liste.append(int(x)) n_zahl = 1 counter += 1 print('multiplikative Ziffernwurzel:', liste[0], '\nBeharrlichkeit:', counter)
Kommentare:
Für diese Lösung gibt es noch keinen Kommentar
Seite 1 von 0
1