Byla vydána (𝕏) nová verze 24.7 open source firewallové a routovací platformy OPNsense (Wikipedie). Jedná se o fork pfSense postavený na FreeBSD. Kódový název OPNsense 24.7 je Thriving Tiger. Přehled novinek v příspěvku na fóru.
Binarly REsearch upozorňuje na bezpečnostní problém PKFail (YouTube) v ekosystému UEFI. Stovky modelů zařízení používají pro Secure Boot testovací Platform Key vygenerovaný American Megatrends International (AMI) a jeho privátní část byla při úniku dat prozrazena. Do milionů zařízení (seznam v pdf) po celém světě tak útočníci mohou do Secure Bootu vložit podepsaný malware. Otestovat firmware si lze na stránce pk.fail. Ukázka PoC na Linuxu na Windows na YouTube.
Mobilní operační systém /e/OS (Wikipedie) založený na Androidu / LineageOS, ale bez aplikací a služeb od Googlu, byl vydán ve verzi 2.2 (Mastodon, 𝕏). Přehled novinek na GitLabu. Vypíchnuta je rodičovská kontrola.
Společnost OpenAI představila vyhledávač SearchGPT propojující OpenAI modely umělé inteligence a informace z webů v reálném čase. Zatím jako prototyp pro vybrané uživatele. Zapsat se lze do pořadníku čekatelů.
Distribuce Linux Mint 22 „Wilma“ byla vydána. Je založená na Ubuntu 24.04 LTS, ale s desktopovým prostředím Cinnamon (aktuálně verze 6.2), příp. MATE nebo Xfce, balíkem aplikací XApp, integrací balíčků Flatpak a dalšími změnami. Více v přehledu novinek a poznámkách k vydání.
Příspěvek na blogu Truffle Security: Kdokoli může přistupovat ke smazaným a privátním repozitářům na GitHubu.
Byla vydána nová verze 14 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v cgitu. Vypíchnout lze podporu rozšíření v Lua.
Byla vydána verze 1.80.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
Apple oznámil, že v beta verzi spustil své Apple Maps na webu. Podporován je také webový prohlížeč Chrome. Ne však na Linuxu.
Portál Stack Overflow po roce opět vyzpovídal své uživatele, jedná se především o vývojáře softwaru, a zveřejnil detailní výsledky průzkumu. Průzkumu se letos zúčastnilo více než 65 tisíc vývojářů. Z Česka jich bylo 710. Ze Slovenska 246.
import string string_array = ['Jozko', 'mal', 'mal', 'ranajky', 'polievku', 'zvysila','Jozko', 'mal','mal', 'sa', 'mu', 'od', 'vcera','polievku','zvysila'] for i in range(len(string_array)): if string_array.count(string_array[i]) > 1: added_word_counter = 0 while True: added_word_counter += 1 searched_string = string_array[i] for j in range(added_word_counter): searched_string += ' ' + string_array[i + j + 1] if string.count(searched_string) > 1: print '>>>>' + searched_string + ': ' + str(string.count(searched_string)) else: breaka malo by to vypisat :
>>>>Jozko mal mal >>>>>polevku zvysilaale vypisuje mi tam nejaku chybu...vie nniekto poradit?
Řešení dotazu:
if string.countNevola se nahodou metoda na objekt ne na modul?
Traceback (most recent call last): File "test.py", line 14, in <module> if string.count(searched_string) > 1: File "/usr/lib/python2.7/string.py", line 348, in count return s.count(*args) TypeError: count() takes at least 1 argument (0 given)Pak se stačí podívat do dokumentace, co vlastně metoda
count
očekává.
cnts = {} for word in string_array: cnts[word] = cnt.setdefault(word,0) + 1
ale vypisuje mi tam nejaku chybu...vie nniekto poradit?Napadla mě nějaká rada.
" ".join(string_array[i:j])Podobnych konstrukci kterymi si jen hazis klacky pod nohy tam mas vice, ale bez znalosti zadani tezko radit.
A B A B C A B C D A B C D EMá se vypsat pouze
A B
, protože je tam nejvícekrát, pouze A B C D
, protože je nejdelší, něco jiného ...?
A B C B C D C D A D A BTady by se mělo vypsat co? Jsou tam čtyři sekvence, které se všechny vyskytují právě dvakrát, a překrývají se. Takový problém je prostě zapotřebí specifikovat přesně.
#!/usr/bin/python import sys, re def only_multiple_occurences(d): return dict((k, v) for k, v in d.iteritems() if len(v) > 1) def add_to_dict_list(d, k, x): if k in d: d[k].append(x) else: d[k] = [x] # Get words. words = list(re.findall(r'\w+', sys.stdin.read())) nwords = len(words) # Find all bigrams with mutliple occurences and gather their positions. n = 2 allngrams = [None, words, {}] ngrams = allngrams[n] for i in range(nwords+1-n): add_to_dict_list(ngrams, tuple(words[i:i+2]), i) allngrams[n] = only_multiple_occurences(ngrams) # Find all longer n-grams, searching only at positions of already found shorter # n-grams. while allngrams[n]: prevngrams = allngrams[n] n += 1 allngrams.append({}) ngrams = allngrams[n] for prevngram, positions in prevngrams.iteritems(): for i in positions: if i + n <= nwords: add_to_dict_list(ngrams, prevngram + (words[i+n-1],), i) allngrams[n] = only_multiple_occurences(ngrams) # Print the n-grams, starting from the longest while excluding all n-grams that # are part of any longer n-gram. n -= 1 excluded = {} while n >= 2: nextexcluded = set() for ngram, positions in allngrams[n].iteritems(): if ngram not in excluded: print ' '.join(ngram) + ' (%ux)' % len(positions) nextexcluded.add(tuple(ngram[1:])) nextexcluded.add(tuple(ngram[:-1])) excluded = nextexcluded n -= 1
1. Behem prvniho pruchodu presstring_array
zjistit pocet vyskutu vsech slov a neuvazovat ty, ktere se vyskutuji min nez 2 krat 2. Behem druheho pruchodu presstring_array
najit nejdelsi retezec, jehoz vsechna slova, jsou v seznamu (slovniku) vytvorenem v 1.kroku 3. Konec
string_array = ['Jozko', 'mal', 'mal', 'ranajky', 'polievku', 'zvysila','Jozko', 'mal','mal', 'sa', 'mu', 'od', 'vcera','polievku','zvysila'] #Prvni pruchod - pocitani vyskytu cnts = {} for word in string_array: cnts[word] = cnts.setdefault(word,0) + 1 valids = [v for v in cnts.keys() if cnts[v] > 1] #Druhy pruchod - hledani nejdelsiho vyhovujiciho retezce max = {'beg': 0, 'end': 0} cur = {'beg': 0, 'end': 0} for pos in range(len(string_array)): if string_array[pos] in valids: cur['end'] += 1 if not string_array[cur['beg']] in valids: cur['beg'] = pos else: if (cur['end'] - cur['beg']) > (max['end'] - max['beg']): max['end'] = cur['end'] max['beg'] = cur['beg'] cur['beg'] = pos cur['end'] = pos print string_array[max['beg']:max['end']+1]
Jozko mal mal polevku zvysilapotom nedokáže v deseti příspěvcích popsat, co to přesně má dělat obecně, a na otázky po upřesnění odpovídá nejasnými kecy, které lze interpretovat deseti způsoby, a nakonec označí za řešení nesmyslný program jiného experta, který nevypíše, co má, ani na tom zasraném jednoduchém úvodním příkladu, natož na těch A B C..., které jsem psal já. Pokud Kamile napíšeš (resp. nenapíšeš, toho jsi nebyl schopen, a muselo se to z tebe složitě dostávat), že má program najít nějaké nejdelší opakující se podsekvence a tenhle program považuješ za řešení, tak se nech vyšetřit. A hlavně se prosím nikdy nepokoušej o programování.
A B C A B C A B C A B C
Tiskni
Sdílej: