Python :: Aufgabe #348 :: Lösung #2

4 Lösungen Lösungen öffentlich
#348

Noch mehr Mustervergleiche (word pattern)

Fortgeschrittener - Python von JKooP - 17.04.2021 um 19:10 Uhr
Gegeben ist ein Text (String), der ausschließlich aus kleingeschriebenen Wörtern besteht,
welche durch Leerzeichen getrennt sind.
Weiterhin gibt es eine Sequenz (String) mit der der Text verglichen werden soll (Mustergleichheit).

Beispiele:
t = "hund katze katze hund"
s = "abba"
Lösung: wahr => a = hund; b = katze; b = katze; a = hund

t = "hund katze maus hund"
s = "abba"
Lösung: falsch => a = hund; b = katze; b = maus; a = hund (b ist unterschiedlich)

t = "hund hund hund hund"
s = "aaa"
Lösung: falsch => Anzahl stimmt nicht überein

Schreibe eine Methode/Funktion, mit der man die Mustergleichheit überprüfen kann.
Als fakultative Herausforderung: ohne die implementierten Funktionen wie etwa Dictionary, map, set, zip, etc.

Viel Spaß
#2
vote_ok
von AlexGroeg (2010 Punkte) - 07.05.2021 um 11:01 Uhr
Quellcode ausblenden Python-Code

def in_zahlenmuster(s):
    m = ''
    muster = ''
    for i in s: 
        if i not in m:
            m += i
        if i in m:
            muster += str(m.index(i))    
    print(muster)        
    return muster

def ist_isomorph(s1, s2):
    if in_zahlenmuster(s1) == in_zahlenmuster(s2):
        return True
    
    return False
 
 
beispiele = [("hund katze katze hund", "abba"),
             ("hund katze maus hund", "abba"),
             ("hund hund hund hund", "aaa")]


for s1, s2 in beispiele:        
    s1n = []
    for i in str.split(s1,' '): 
        s1n.append(i[0])
    print('s1 = {}; s2 = {}  => {}'.format(s1, s2, ist_isomorph(s1n, s2)))

Kommentare:

Für diese Lösung gibt es noch keinen Kommentar

Bitte melden Sie sich an um eine Kommentar zu schreiben.
Kommentar schreiben