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

[C++] operatory binarne, przesunięcie bitowe, not

0 głosów
168 wizyt
pytanie zadane 20 czerwca 2018 w C i C++ przez Hiskiel Pasjonat (22,850 p.)

Witam.

 

Napisałem dla testu taki kod:

#include <iostream>

#define L_SH(x,y) ((x)<<(y))
#define R_SH(x,y) ((x)>>(y))

int main(){
    std::cout<<"Enter math expression: \n";
    std::cout<< (5 | 3) <<"\n"; // 0101 | 0011 = 0111 (7)
    std::cout<< (5 & 3) <<"\n"; // 0101 & 0011 = 0001 (1)
    std::cout<< (5 ^ 3) <<"\n"; // 0101 ^ 0011 = 0100 (4)
    std::cout<< ~5 <<" "<< ~3 <<"\n"; // ~0101 ~0011 = 1010 (10) 1100 (12)
    std::cout<< ~-5 <<" "<< ~-3 <<"\n\n"; // ?

    std::cout<<"LEFT: 20 - 1, 2\n";
    std::cout<< L_SH(20, 1) <<"  "<< L_SH(20, 2) <<"\n\n"; // 10100 <<1 01000 (8) - 10100 <<2 10000 (16)
    std::cout<<"RIGHT: 20 - 1, 2\n";
    std::cout<< R_SH(20, 1) <<"  "<< R_SH(20, 2) <<"\n\n"; // 10100 1>> 01010 (10) - 10100 2>> 00101 (5)

}

Mam taki output:

Enter math expression:
7 (or)
1 (and)
6 (xor)
-6 -4 (not +)
4 2 (not -)

LEFT: 20 - 1, 2 (bit shift)
40  80 

RIGHT: 20 - 1, 2 (bit shift)
10  5

(to co w nawiasach dopisałem dla łatwiejszej orientacji)

O ile or, and, xor, not z dodatnim rozumiem, o tyle nie wiem dlaczego not z ujemnym daje wyniki 4, 2. Czy mógłby mi ktoś wyjaśnić jak mniej więcej powinna wyglądać treść tamtego komentarza? Dlaczego wyniki są takie, a nie inne?

Dodatkowo. Zdziwiło mnie kiedy przy komentowaniu lewego przesunięcia bitowego wychodziły mi te wyniki. Po włączeniu programu okazało się, iż byłem w błędzie i wyniki są prawidłowe. Czy mógłby mnie ktoś wyprowadzić z błędu?

 

Pozdrawiam.

1 odpowiedź

+1 głos
odpowiedź 20 czerwca 2018 przez RafalS VIP (122,820 p.)
wybrane 25 czerwca 2018 przez Hiskiel
 
Najlepsza
	std::cout << std::bitset<32>(-5) << std::endl;
	std::cout << std::bitset<32>(~-5) << std::endl;
	std::cout << std::bitset<32>(-3) << std::endl;
	std::cout << std::bitset<32>(~-3) << std::endl;

Dodaj te linijki i gdy dalej nie będziesz rozumiał to poczytaj o kodowaniu U2 (uzupełnienie do dwóch).

Drugiej części pytania totalnie nie rozumiem.

komentarz 20 czerwca 2018 przez Hiskiel Pasjonat (22,850 p.)

Przepraszam bardzo, dziwnie to napisałem. 

Chodzi o to, że przed włączeniem programu gdy pisałem te std::cout to zaraz po nich komentowałem jak może wyglądać output, w sensie wyobrażałem sobie (oraz rozpisywałem w tych komentarzach) jaki będzie wynik i jak to będzie przebiegać, jednakże przy tym przesunięciu bitowym w lewo 20, 1 - 20, 2 wyniki mnie zdziwiły. Struktura komentarza wygląda mniej więcej tak:

1. 10100 
2. <<1 
3. 01000 (8) - 

1. aktualna liczba w binarce
2. znak przesunięcia bitowego oraz ilość przesunięć.
3. Możliwy wynik.

 

komentarz 20 czerwca 2018 przez RafalS VIP (122,820 p.)
Niedawno był taki bardzo długi wątek na ten sam temat. Nie wiem czemu przyjąłeś, że liczba jest reprezentowana na 5 bitach :D. Na prawdę masz tam pewnie jeszcze 17 zer z przodu, bo rozmiar inta 32 bity (nie zawsze ale najczesciej). I w miejsce tych zer ucieka Ci jedynka o której zapominasz.
komentarz 25 czerwca 2018 przez Hiskiel Pasjonat (22,850 p.)

Dzięki wielkie smiley

Podobne pytania

0 głosów
0 odpowiedzi 87 wizyt
pytanie zadane 10 sierpnia 2020 w C i C++ przez fortuna Początkujący (310 p.)
+1 głos
1 odpowiedź 93 wizyt
pytanie zadane 19 czerwca w JavaScript przez greg456 Nowicjusz (190 p.)
0 głosów
0 odpowiedzi 131 wizyt
pytanie zadane 10 sierpnia 2020 w C i C++ przez fortuna Początkujący (310 p.)
Porady nie od parady
Publikując kody źródłowe korzystaj ze specjalnego bloczku koloryzującego składnię (przycisk z napisem code w edytorze). Nie zapomnij o ustawieniu odpowiedniego języka z rozwijanego menu oraz czytelnym formatowaniu kodu.Przycisk code

85,698 zapytań

134,499 odpowiedzi

298,514 komentarzy

56,625 pasjonatów

Motyw:

Akcja Pajacyk

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

Oto dwie polecane książki warte uwagi. Pełną listę znajdziesz tutaj.

...