+ 11

This is a challenge question in sololearn.

X=1-(-1==~0). I think the answer should be 1 But it is given 0 ? Help

26th Aug 2019, 5:53 PM
Kesh∆v
Kesh∆v - avatar
4 Answers
+ 16
~ is not operator. ~0 is -1 (signed arithmetic) So 1-(-1 == ~0) = 1-(-1 == -1) = 1-1 = 0
26th Aug 2019, 6:02 PM
Théophile
Théophile - avatar
+ 4
You have to consider how signed binary numbers work. Let's use a byte sized number for this: 00000000b now, ~00000000 simply means that C treats the decimal number as a string of binary digits, and inverts binary digits of that number. Keep in mind the Most Significant Bit (MSB, the left-most one) is the sign bit: sign magnitude 1 1111111 This is then converted to decimal: 11111111 = -127 + 64 + 32 + 16 + 8 + 4 + 2 + 1 = -1 Now plug this into the expression: x = 1 -(-1 == (-1)) x = 1 - (1) : since -1 does equal -1, the result is true. In a program, this is automatically typecasted to be a signed integer. x = 0 And there you have it.
27th Aug 2019, 3:35 PM
BootInk
BootInk - avatar
+ 4
Esto tiene que ver con el complemento a 1 y complemento a 2. ÂżQuĂ© son estas cosas? Hubo un tiempo, en electrĂłnica, que necesitaron representar nĂșmeros negativos en el mismo espacio que los positivos: esto se puede hacer invirtiendo los bits, miramos si el MSB es 1 y si lo es el nĂșmero serĂĄ negativo, lo Ășnico que los 0 serĂĄn 1 y los 1 0. Ejemplo: 1: 0001 -1: 1110 Pero tuvieron un problema muy molesto: existĂ­an dos 0, el positivo y el negativo. 0: 0000 -0: 1111 Veamos: -1 + 1 = -0 1110 + 0001 = 1111 ÂżY -0 + 1 = 0? 1111 + 0001 = 0000 Eso no era bueno (hay electrĂłnica que aĂșn funciona asĂ­, por ejemplo los testers electrĂłnicos). AsĂ­ que alguien pensĂł en sumar 1 al complemento. AsĂ­ se pudo hacer que -1 + 1 = 0 -1 = ~(-1)+1 = 1110 + 0001 = 1111 Entonces -1 + 1 = 0: 1111 + 0001 = 0000 A la forma mĂĄs antigua lo llamaron complemento a 1 y a la mĂĄs moderna complemento a 2. Por eso ~0 es el complemento a 1 de 0, es decir 1111 Y -1 es el complemento a 2 de 1, eso es 1111, por eso son iguales.
27th Aug 2019, 7:24 PM
Miquel Andreu Fuster Sancho
Miquel Andreu Fuster Sancho - avatar
+ 3
As in bracket first solving properly the answer will come out to be 1 then subtracting It from 1 we get 0,here the bitwise and normal subtraction is taking place in this question
28th Aug 2019, 1:27 AM
Yatin Verma
Yatin Verma - avatar