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

Mnożenie liczb binarnych metodą "przesuń i dodaj" - system uzupełnień do 2

Object Storage Arubacloud
0 głosów
2,341 wizyt
pytanie zadane 12 listopada 2017 w Algorytmy przez Lupusvulpes Nowicjusz (140 p.)

Mam 3 pytania odnośnie powyższej metody, odpowiednio kolory i cyfry jak na rysunku:

1. Wykonywana jest operacja przesunięcia bitowego. Dlaczego w zielonych kołach- wnioskuję- przesunięcie odbywa się z dopełnieniem jedynkami, a przy pozostałych przesunięciach zerami ??

2. Dlaczego w ogóle są wykonywane takie a nie inne operacje w danej sekwencji i mnożenie kończy się na takim etapie ? Ewentaulnie jak by to wyglądało dla innych liczb - po czym mogę wnioskować że mnożenie jest zakończone; otrzymałem pożądany wynik ?

3. 11101 11010 = - 70

Nie rozumiem jak; przerabiając materiał nauczyłem się tak:

Pierwsze miejsce ciągu bitów odpowiada za znak- a więc obie części są ujemne (?) wtedy:

-(1*2^3 + 1*2^2 + 0*2^1 + 1*2^0) * 10^1 + (-(1*2^3 + 0 * 2^2 + 1*2^1 + 0*2^0) *10^0
Tak rozpisałem te dwa człony według, wynik byłby -130 -10 = -140. Gdzie leży błąd w moim rozumowaniu ?

 

Przepraszam jeżeli coś jest bardzo banalne, ale jestem nowy z informatyką i nie wszystko jest dla mnie oczywiste. Siedzę nad tym ze 2 godziny i pomimo trudów udało mi się dojść do takiego stopnia zrozumienia :P
Dziękuję serdecznie za pomoc ;)

1 odpowiedź

0 głosów
odpowiedź 12 listopada 2017 przez Patrycjerz Mędrzec (192,320 p.)
  1. Przesunięcie w prawo odbywa się z dopełnieniem jedynkami, gdy bit S jest jedynką.
  2. Mnożenie jest zakończone, gdy wykonasz ilość przesunięć równą długości czynników (w tym przypadku 5).
  3. Analizuj liczbę jako całość, czyli 10 bitów. Wtedy pierwszy bit posiada wagę ujemną, reszta dodatnią. Po wyliczeniu wychodzi właśnie -70.

Podobne pytania

0 głosów
0 odpowiedzi 33 wizyt
0 głosów
0 odpowiedzi 122 wizyt
pytanie zadane 18 listopada 2023 w Matematyka, fizyka, logika przez Kr1zu Nowicjusz (120 p.)
–1 głos
2 odpowiedzi 279 wizyt
pytanie zadane 23 marca 2019 w C i C++ przez mikolaj_d Nowicjusz (120 p.)

92,539 zapytań

141,382 odpowiedzi

319,476 komentarzy

61,928 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!

...