• 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

Aruba Cloud VPS - 50% taniej przez 3 miesiące!
0 głosów
2,535 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 109 wizyt
0 głosów
0 odpowiedzi 186 wizyt
pytanie zadane 18 listopada 2023 w Matematyka, fizyka, logika przez Kr1zu Nowicjusz (120 p.)
–2 głosów
0 odpowiedzi 217 wizyt

93,180 zapytań

142,195 odpowiedzi

321,992 komentarzy

62,511 pasjonatów

Advent of Code 2024

Top 15 użytkowników

  1. 1873p. - dia-Chann
  2. 1848p. - Łukasz Piwowar
  3. 1831p. - CC PL
  4. 1827p. - Łukasz Eckert
  5. 1789p. - Tomasz Bielak
  6. 1769p. - Michal Drewniak
  7. 1761p. - Łukasz Siedlecki
  8. 1758p. - rucin93
  9. 1708p. - Adrian Wieprzkowicz
  10. 1668p. - Mikbac
  11. 1621p. - rafalszastok
  12. 1506p. - Marcin Putra
  13. 1356p. - ssynowiec
  14. 1289p. - Anonim 3619784
  15. 1232p. - Mariusz Fornal
Szczegóły i pełne wyniki

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

Wprowadzenie do ITsec, tom 1 Wprowadzenie do ITsec, tom 2

Można już zamawiać dwa tomy książek o ITsec pt. "Wprowadzenie do bezpieczeństwa IT" - mamy dla Was kod: pasja (użyjcie go w koszyku), dzięki któremu uzyskamy aż 15% zniżki! Dziękujemy ekipie Sekuraka za fajny rabat dla naszej Społeczności!

...