Python :: Aufgabe #358 :: Lösung #3
3 Lösungen
#358
String abwechselnd neu anordnen
Anfänger - Python
von JKooP
- 15.05.2021 um 10:48 Uhr
Gegeben ist ein String (Text) bestehend aus Kleinbuchstaben und Ziffern.
Ziel ist es diesen String neu anzuordnen, sodass sich Kleinbuchstaben und Ziffern abwechseln.
D.h., auf einen Kleinbuchstaben darf kein Kleinbuchstabe und auf eine Ziffer keine weitere Ziffer folgen.
Die Reihenfolge der Zeichen-Gruppen (Kleinbuchstaben bzw. Ziffern) darf nicht verändert werden.
Sind beide Zeichengruppen gleich lang, ist es egal mit welchem Zeichen begonnen wird.
Gibt es keine Lösung, soll ein Leer-String zurückgegeben werden.
Beispiele:
s = "train1234"
Lösung: "t1r2a3i4n"
s = "1234567"
Lösung: "", da nur Ziffern
s = "abcdefg"
Lösung: "", da nur Buchstaben
s = "abcdef123"
Lösung: "", nicht abwechselnd möglich
s = "abcd1234"
Lösung: "a1b2c3d4" oder "1a2b3c4d"
Schreibe eine Methode/Funktion, die obige Aufgabenstellung umsetzt.
Viel Spaß
Ziel ist es diesen String neu anzuordnen, sodass sich Kleinbuchstaben und Ziffern abwechseln.
D.h., auf einen Kleinbuchstaben darf kein Kleinbuchstabe und auf eine Ziffer keine weitere Ziffer folgen.
Die Reihenfolge der Zeichen-Gruppen (Kleinbuchstaben bzw. Ziffern) darf nicht verändert werden.
Sind beide Zeichengruppen gleich lang, ist es egal mit welchem Zeichen begonnen wird.
Gibt es keine Lösung, soll ein Leer-String zurückgegeben werden.
Beispiele:
s = "train1234"
Lösung: "t1r2a3i4n"
s = "1234567"
Lösung: "", da nur Ziffern
s = "abcdefg"
Lösung: "", da nur Buchstaben
s = "abcdef123"
Lösung: "", nicht abwechselnd möglich
s = "abcd1234"
Lösung: "a1b2c3d4" oder "1a2b3c4d"
Schreibe eine Methode/Funktion, die obige Aufgabenstellung umsetzt.
Viel Spaß
#3
von JJP (40 Punkte)
- 07.07.2021 um 12:04 Uhr
Python-Code
def mix_word(string): #1 number = [] letter = [] for symbol in string: if symbol in list("1234567890"): number.append(symbol) else: letter.append(symbol) #2 if max(len(number), len(letter)) - min(len(number), len(letter)) > 1: return None #3 if len(number) > len(letter): size = [number, letter] else: size = [letter, number] #4 string = "" for symbol in range(len(size[0])): string += (size[0][symbol]) if not len(size[1]) - symbol <= 0: string += (size[1][symbol]) return string """ The program: 1. It splits the word into numbers and letters 2. searches an error 3. sorts the list by length 4. and mixes it The variables: string: is the word, that should to be mixed - later it is the mixed word number: contains all the numbers of the string letter: contains letters (also symbols and space) of the string symbol: goes through the items of the string size: [0] is the bigger list, [1] is the smaller list """
Kommentare:
Für diese Lösung gibt es noch keinen Kommentar
Seite 1 von 0
1