Hirdetés
- bambano: Bambanő háza tája
- gban: Ingyen kellene, de tegnapra
- sziku69: Fűzzük össze a szavakat :)
- Luck Dragon: Asszociációs játék. :)
- Magga: PLEX: multimédia az egész lakásban
- sziku69: Szólánc.
- Pajac: A csodálatos mandarin
- Brogyi: CTEK akkumulátor töltő és másolatai
- droidic: Windows 11 önállóság nélküli világ: a kontroll új korszaka
- Lalikiraly: Kinek milyen setupja van?
-
LOGOUT

Új hozzászólás Aktív témák
-
válasz
#83580928
#12429
üzenetére
Van erre egy viszonylag egyszeru modszer is amugy:
Mivel csak a leghoszabb ismetlodo kell, mas nem (hanyszor ismetlodik, hany darab ismetlodo van, stb), ezert eleg egyszeruen megirhato, ami ugy nez ki, hogy kezdesz a string hossza / 2-tol (compareLength), es ezt lepteted 1-esevel lefele, illetve compLength-hasonlitgatsz szeleteket, a stringen meg egyesevel lepkedsz elore (i). Egy masik ciklus meg annyit csinal, hogy (i) + compareLength-rol indul, es egyesevel compareLength meretu string szeleteket hasonlit ossze az elso ciklusbol kieso szelettel. Az elso adando alkalommal, amikor talal valamit, megvan a leghoszabb egyezes (mivel a leheto legnagyobb ismetlodo string az, ha a teljes hosszaban ketszer szerepel ugyanaz).Ez se tul optimalis, de nem olyan nehez megirni, es azert annyira nem veszesen lassu.
Direkt nem irtam hozza kodot (meg pszeudot sem), mert igy meg kell erteni az implementalashoz a mindent.

-
Domonkos
addikt
válasz
#83580928
#12429
üzenetére
text=input().lower()
rep = []
for a in range(len(text)):
for b in range(a+1,len(text)):
ans = ''
i = 0
while (i < len(text) - b):
if text[a+i] == text[b+i] :
ans+= text[b+i]
i+=1
else:
break
rep.append(ans)
m = ''
for i in rep:
if len(i)>len(m):
m = i
if m == '':
print('None')
else:
print(m)Nem optimalis, de szerintem ertheto.
-
#83580928
törölt tag
válasz
#83580928
#12429
üzenetére
Az úgy például jó elgondolás, hogy mondjuk megnézem az első két karakterláncot (CG) és megnézem string maradék részében, hogy ismétlődik-e, ha igen akkor elmentem egy segédtömbbe. Utána megnézem az első három karaktert, megnézem hogy ismétlődik-e a maradék karakterekben, ha igen elmentem a segédtömb következő indexébe. Így tovább.Viszont ha az első két karakter nem ismétlődik, akkor tovább ugrok a következőre (GA).Ha mondjuk egy változóban mindig tárolnám a leghosszabb hosszt és ha mondjuk az elején lenne egy 4 karakternyi hosszúságú ismétlődés, akkor azután már 5 karakternyi hosszúságút keressen, mert a többi nem érdekel minket. Sokkal kevesebb találat lenne és kevesebb adat is kerülne a segédtömbbe. Ez így jó ? Meg eleve csak a string feléig kell keresnem, mert utána már nem ismétlődhet.
Példa: CGACCGACCGAT
Új hozzászólás Aktív témák
● olvasd el a téma összefoglalót!
- Milyen légkondit a lakásba?
- Milyen TV-t vegyek?
- Polgári repülőgép-szimulátorok
- Folytatja küzdelmét az Intel az NVIDIA (és az AMD) ellen
- Project Motor Racing-Straight4 Studios
- A Gemini húzza ki a Sirit a csávából
- Fejhallgató erősítő és DAC topik
- Milyen széket vegyek?
- exHWSW - Értünk mindenhez IS
- OLED monitor topic
- További aktív témák...
- Xbox 360 Slim 500GB Rgh 3.0 azonnali bootolás! + játékok, 1 év gar. 24 éve működő üzletből!
- XBOX Series S/X/One/S/X/360 konzolok teljes karbantartása, pasztázással Thermal Grizzly 1 órán belül
- XBOX One/S/X/360 Series S/X konzolok teljes karbantartása, pasztázással Thermal Grizzly 1 órán belül
- Xbox Series X, kitisztítva+újrapasztázva, 6 hó teljeskörű gar., Bp-i üzletből eladó!
- Nintendo Switch RP2040-tiny Picofly 2.80fw CFW chip (Lite/V1/V2/OLED) készlet 1 év garanciával eladó
- ÁRGARANCIA!Épített KomPhone Ryzen 7 7800X3D 32/64GB RAM RTX 5090 32GB GAMER PC termékbeszámítással
- Általános igazgatóhelyettes tábla üvegből eladó
- Apple iPhone 15 Pro 128GB, Kártyafüggetlen, 1 Év Garanciával
- Eredeti Lenovo 65W USB Type C notebook töltő
- Gamer PC-Számítógép! Csere-Beszámítás! I7 12700E / RTX 3060Ti / 32GB DDR4 / 512GB Nvme SSD
Állásajánlatok
Cég: Laptopműhely Bt.
Város: Budapest
Cég: NetGo.hu Kft.
Város: Gödöllő



