V Bolzanu probíhá konference SFSCON (South Tyrol Free Software Conference). Jean-Baptiste Kempf, zakladatel a prezident VideoLAN a klíčový vývojář VLC media playeru, byl na ní oceněn cenou European SFS Award 2025 udělovanou Free Software Foundation Europe (FSFE) a Linux User Group Bolzano‑Bozen (LUGBZ).
Open-source minimalistický trackball Ploopy Nano byl po modelech modelech Classic a Thumb Trackball také aktualizován. Nová verze Nano 2 používá optický senzor PAW3222 a k původně beztlačítkovému designu přidává jedno tlačítko, které ve výchozí konfiguraci firmwaru QMK přepíná režim posouvání koulí. Sestavený trackball nyní vyjde na 60 kanadských dolarů (bez dopravy a DPH).
Github publikoval Octoverse 2025 (YouTube), tj. každoroční přehled o stavu open source a veřejných softwarových projektů na GitHubu. Každou sekundu se připojil více než jeden nový vývojář. Nejpoužívanějším programovacím jazykem se stal TypeScript.
Kit je nový maskot webového prohlížeče Firefox.
Mastodon (Wikipedie) - sociální síť, která není na prodej - byl vydán ve verzi 4.5. Přehled novinek s náhledy v oznámení na blogu.
Německo zvažuje, že zaplatí místním telekomunikačním operátorům včetně Deutsche Telekom, aby nahradili zařízení od čínské firmy Huawei. Náklady na výměnu by mohly přesáhnout dvě miliardy eur (bezmála 49 miliard Kč). Jeden scénář počítá s tím, že vláda na tento záměr použije prostředky určené na obranu či infrastrukturu.
Po dvaceti letech skončil leader japonské SUMO (SUpport.MOzilla.org) komunity Marsf. Důvodem bylo nasazení sumobota, který nedodržuje nastavené postupy a hrubě zasahuje do překladů i archivů. Marsf zároveň zakázal použití svých příspěvků a dat k učení sumobota a AI a požádal o vyřazení svých dat ze všech učebních dat.
Úřad pro ochranu hospodářské soutěže zahajuje sektorové šetření v oblasti mobilních telekomunikačních služeb poskytovaných domácnostem v České republice. Z poznatků získaných na základě prvotní analýzy provedené ve spolupráci s Českým telekomunikačním úřadem (ČTÚ) ÚOHS zjistil, že vzájemné vztahy mezi operátory je zapotřebí detailněji prověřit kvůli možné nefunkčnosti některých aspektů konkurence na trzích, na nichž roste tržní podíl klíčových hráčů a naopak klesá význam nezávislých virtuálních operátorů.
Různé audity bezpečnostních systémů pařížského muzea Louvre odhalily závažné problémy v oblasti kybernetické bezpečnosti a tyto problémy přetrvávaly déle než deset let. Jeden z těchto auditů, který v roce 2014 provedla francouzská národní agentura pro kybernetickou bezpečnost, například ukázal, že heslo do kamerového systému muzea bylo „Louvre“. 😀
Z upstreamu GNOME Mutter byl zcela odstraněn backend X11. GNOME 50 tedy poběží už pouze nad Waylandem. Aplikace pro X11 budou využívat XWayland.
import sys
import string
WEIGHT = (6, 3, 7, 9, 10, 5, 8, 4, 2, 1)
def get_digits(number):
return [int(digit) for digit in number]
def validate_number(number):
chk = sum([w * i for w, i in zip(WEIGHT, get_digits(number))])
return chk % 11 == 0
def search_numbers(number):
if len(number) != 10:
return None
letters = set()
for letter in string.ascii_lowercase:
if letter in number:
letters.add(letter)
numbers = []
for i in range(10 ** len(letters)):
tested = number
for letter, num in zip(letters, get_digits(f'{i:0{len(letters)}d}')):
tested = tested.replace(letter, str(num))
if validate_number(tested):
numbers.append(tested)
return sorted(numbers)
def _main(number):
numbers = search_numbers(number)
if numbers is None:
print("account number must have 10 characters")
for num in numbers:
print(num)
if __name__ == '__main__':
_main(sys.argv[1])
vstup môže byť napríklad 1234abcdaa a to bude za pismenka doplňovať rôzne kombinácie a vypíše ktoré sú vyhovujú, napr:
$ python3 search.py 1234aaabbb 1234000999 1234111111 1234222444 1234333777 1234555222 1234666555 1234777888 1234888000 1234999333 $ python3 search.py 00aaaabbbb 0000000000 0011116666 0022221111 0033337777 0044442222 0055558888 0066663333 0077779999 0088884444 $ python3 number_search.py 00abababab 0000000000 0019191919 0027272727 0035353535 0043434343 0051515151 0078787878 0086868686 0094949494takto sa dajú nájsť rôzne kombinácie ľahko zapamatateľných čísel.
Tiskni
Sdílej:
todleto bytě jako mohlo zajímat pane vlk hele :O :O ;D ;D
ten zoreček jak ho tam maj popsanej asi jako nefunguje ale se zahrnutím tý váhy druhý číslice zprava snad jakoby jo. je tam jediná vyjímka ato když je zbytek po dělení dvojka. řešim to hejbáním uplně nejposlednější cifričkou napravo v čísle. pokud bysme vybrali jako tamtu modulo pozici poslední cifričku s váhou 1 tak zase nenajdem řešení pro zbytek 1 protože desítku na pozici jedný cifry nenacpem stejně jako u tý předposlední u zbytku 2 :O :O :D ;D
si teda jako myslim že nám stačí mit závislý jenom nějaký dvě zvolený cifry v tom čísle abysme z uplně jakýhokoliv zbytku mohli jakoby udělat něco dělitelnýho bezezbytku jedenáctma noa s vostatníma ciframa čísla si mužem moct dělat uplně co chcem a nebudem muset dělat řešení hrubou silou :D :D ;D ;D
#!/usr/bin/python3
WEIGHT = (6, 3, 7, 9, 10, 5, 8, 4, 2, 1)
def validate_number(number):
chk = sum([w * i for w, i in zip(WEIGHT, number)])
return chk % 11 == 0
# kontrolni pozice je předposlední číslice v čísle účtu
def dopocitej_kontrolni_pozici(number):
chk = sum([w * i for w, i in zip(WEIGHT, number)])
zbytek = chk % 11
# zbytek plus co je dělitelný bezezbytku jedenácti?? :O ;D
# předposlední pozice má váhu 2 takže budem skákat po dvojkách od nuly po 18
# mužem najít pro všecky hodnoty zbytku kromě dvojky protože desítku (abysme měli 22) do jedný
# jediný cifričky prostě nenacpem ikdbyby sme jakoby děsně moc chtěli :/ :/
# asi to maj v tom popisu blbě ale nevim
if zbytek != 2:
for x in range(0,10):
if (zbytek + x*2) % 11 == 0:
number[-2] = x
return True
# když máme zbytek 2 uděláme úpravu nejposlednější čísličky napravo co má váhu jedna
# takže hejbnem celým zbytkem o jedna
# lepší řešení mě nenapadlo :/ :/
else:
if number[-1] < 9:
number[-1] += 1
number[-2] = 4
return True
else:
number[-1] = 8
number[-2] = 5
return True
# funguje to jakoby ždycky???? :O :O :O :O
# nóóó mělo by že :O :O ale projistotu :D :D ;D ;D
return False
# na kontrolní pozici nechávám nuličku by nám to tuhletu hodnotu jakoby přeskočilo
# při dělání sumy
cisla = []
cisla.append([1,2,3,4,5,6,7,8,0,9])
cisla.append([7,7,7,7,7,7,7,7,0,7])
cisla.append([1,2,4,8,6,2,4,8,0,2])
cisla.append([3,1,4,1,5,9,2,6,0,3])
cisla.append([1,1,2,3,5,8,3,1,0,1])
cisla.append([4,1,8,3,5,8,3,4,0,4])
for num in cisla:
dopocitej_kontrolni_pozici(num)
print(num)
if validate_number(num):
print('cislo je validni')
else:
print('cislo neni validni')