• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

question-closed Kolejne potęgi liczby dwa jako sposób na przechowywanie informacji za pomocą jednej liczby

Object Storage Arubacloud
0 głosów
283 wizyt
pytanie zadane 4 stycznia 2023 w Matematyka, fizyka, logika przez troian1337 Użytkownik (720 p.)
zamknięte 9 stycznia 2023 przez troian1337
Witam, tytuł trochę chaotyczny ale postaram się opisać tutaj dokładnie o co mi chodzi.

Kilka lat temu tworzyłem niewielkie oprogramowanie do prac z API allegro i tam występował bardzo ciekawy system przechowywania informacji o wybranej konfiguracji tylko za pomocą jednej liczby, wyglądało to tak:

Dana liczba jest sumą kolejnych potęg liczby dwa 2^0=1, 2^1=2, 2^2=4, 2^3=8, 2^4=16 ITD

Jeżeli zmienną jest liczba 1 to jej konfiguracja składa się z 1 (2^0)

Jeżeli zmienną jest liczba 3 to jej konfiguracja składa się z 1 (2^0) + 2 (2^1)

Jeżeli zmienną jest liczba 5 to jej konfiguracja składa się z 1 (2^0) + 4 (2^2)

Jeżeli zmienną jest liczba 6 to jej konfiguracja składa się z 2 (2^1) + 4 (2^2)

Jeżeli zmienną jest liczba 7 to jej konfiguracja składa się z 1 (2^0) + 2 (2^1) + 4 (2^2)

Jeżeli zmienną jest liczba 9 to jej konfiguracja składa się z 8 (2^4) + 1 (2^0)

Jeżeli zmienną jest liczba 10 to jej konfiguracja składa się z 8 (2^4) + 2 (2^1)

Jeżeli zmienną jest liczba 15 to jej konfiguracja składa się z 8 (2^4) + 1 (2^0) + 2 (2^1) + 4 (2^2)

Każda potęga może wystąpić TYLKO JEDEN RAZ co uniemożliwia powstania błędu typu 6 = 3 x 2 (2^1)

Kiedyś właśnie jak pisałem ten program znalazłem nazwę tego algorytmu / funkcji oraz wzór, niestety było to lata temu i od tamtej pory nie korzystałem z tej techniki, a z racji iż nie jestem dobry w zapamiętywaniu nazw nie potrafię sobie teraz przypomnieć.

Może ktoś z szanownych forumowiczów kojarzy jaki algorytm / funkcja wykorzystuje w/w przykłady.
komentarz zamknięcia: Znalezione rozwiązanie
komentarz 4 stycznia 2023 przez Whistleroosh Maniak (56,980 p.)

To jest po prostu binarny system liczbowy. Wiele funkcji przyjmuje tzw. flagi, które przetrzymują informacje w sposób który opisałeś np. open

komentarz 9 stycznia 2023 przez troian1337 Użytkownik (720 p.)

O dokładnie tego potrzebowałem :) Dzięki za nakierowanie mnie!

Dla zainteresowanych przykład w PHP: 

$binary = []; 
$test = 65536 + 268435456 + 4294967296 + 1;

for($x=0 ; $x<=32 ; $x++)
{
	$pow = pow(2, $x);
	$binary[] = $pow;
}

foreach ($binary as $value) 
{
    $result = $value & $test;
    $val = (int) sprintf("%1$2d", $result, $value, '&', $test);
	if ($val > 0)
	{
		echo $val."\n";
	}
}

 

Podobne pytania

0 głosów
1 odpowiedź 944 wizyt
pytanie zadane 4 czerwca 2023 w Python przez wojtek_programista Nowicjusz (170 p.)
0 głosów
3 odpowiedzi 171 wizyt

92,576 zapytań

141,426 odpowiedzi

319,652 komentarzy

61,961 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...