Blíží se prázdniny a než se rozutečete k moři, je na čase se opět sejít na Virtuální Bastlírně - pravidelném setkání elektroniků, ajťáků, bastlířů a obecně nadšenců do techniky. Co si pro vás strahovští bastlíři připravili tentokrát? Určitě proberou blížící se Linux Days i další události. U softwaru se chvíli zdrží a poví si kupříkladu o tom, jak se zbavit Bambu Cloudu, ale nepřijít o možnost ovládat tiskárnu na dálku. Řeč dojde i na AI,
… více »Vývojáři postmarketOS vydali verzi 26.06 tohoto operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky. Přehled novinek v příspěvku na blogu. Na výběr jsou 4 uživatelská rozhraní: GNOME, KDE Plasma Mobile, Phosh a Sxmo.
Byla vydána nová verze 2.55.0 distribuovaného systému správy verzí Git. Přispělo 100 vývojářů, z toho 33 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání.
Craig Loewen na blogu Microsoftu oznámil veřejnou preview verzi WSL kontejnerů, tj. linuxových kontejnerů ve Windows Subsystem for Linux (WSL). Spouští se příkazem wslc.exe.
Byla vydána (𝕏, Bluesky) nová verze 2026.2 linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux (Wikipedie). Přehled novinek se seznamem 9 nových nástrojů v oficiálním oznámení na blogu.
Grafická aplikace Krokiet/Czkawka pro vyhledávání a odstraňovaní nepotřebných souborů (duplicitní soubory, prázdné složky, podobné obrázky, podobná videa, poškozené soubory a další) byla vydána ve verzi 12.0.0. Podrobný přehled novinek v příspěvku na Medium. Jedná se o poslední verzi frontendu Czkawka GTK nad Czkawka Core. Uživatelům se doporučuje migrovat na frontend Krokiet postavený nad frameworkem Slint. Představena byla aplikace Cedinia pro Android využívající Czkawka Core. Dostupná je jako APK pro ruční instalaci.
Po téměř třech letech od vydání verze 9 byla vydána nová verze 10 linuxové distribuce Mageia (Wikipedie). Přehled novinek v poznámkách k vydání.
Nourish (GitHub) je nový správce oken pro Linux. Tradiční plochy nahrazuje nekonečným plátnem a posouváním a přibližováním. Využívá vlastní kompozitor pro Wayland s názvem y5. Videoukázka.
Po 20 letech a 17 otevřených (open source) krátkých filmech Blender Studio oznámilo plán na svůj první celovečerní film. Cílem samozřejmě není jenom nový otevřený film, ale především vývoj a vylepšení otevřených nástrojů pro spolupráci napříč celým procesem a vytvoření otevřené příručky (playbook) pro filmovou produkci ve velkém měřítku s informacemi, které jsou obvykle dostupné pouze uvnitř komerčních studií, a pomoci tak nezávislým tvůrcům překonat technické a organizační bariéry.
Byla vydána nová verze 26.6.25 svobodného multiplatformního video editoru Shotcut (Wikipedie) postaveného nad multimediálním frameworkem MLT. Shotcut je vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.
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:
break
a 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.
Porovnavanim vseho na vsechno se daleko nedostanes, budes si muset drzet index ve slovniku. Neni to uplne trivialni uloha a tim spis plati co jsem rikal prve - nejdriv se nauc lepe python. Neni to nic slozityho. Pokud neumis prochazet pole bez range() nema moc smysl resit to dal.
Jen tak pro zajimavost, jakej jazyk jsi delal predtim?
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_arrayzjistit pocet vyskutu vsech slov a neuvazovat ty, ktere se vyskutuji min nez 2 krat 2. Behem druheho pruchodu presstring_arraynajit 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: