Why do unsigned integers wrap without extensively using the modulo operator in c++?? Suppose , Unsigned int a , b; a and b both are 2^32-1. Then what will be the value of a+b?
so if they don't overflow how can we make them overflow??
# | User | Rating |
---|---|---|
1 | jiangly | 4039 |
2 | tourist | 3841 |
3 | jqdai0815 | 3682 |
4 | ksun48 | 3590 |
5 | ecnerwala | 3542 |
6 | Benq | 3535 |
7 | orzdevinwang | 3526 |
8 | gamegame | 3477 |
9 | heuristica | 3357 |
10 | Radewoosh | 3355 |
# | User | Contrib. |
---|---|---|
1 | cry | 168 |
2 | -is-this-fft- | 165 |
3 | atcoder_official | 160 |
3 | Um_nik | 160 |
5 | djm03178 | 157 |
6 | Dominater069 | 156 |
7 | adamant | 153 |
8 | luogu_official | 152 |
9 | awoo | 151 |
10 | TheScrasse | 147 |
Why do unsigned integers wrap without extensively using the modulo operator in c++?? Suppose , Unsigned int a , b; a and b both are 2^32-1. Then what will be the value of a+b?
so if they don't overflow how can we make them overflow??
Name |
---|
why not run it yourself to find out? this seems to be easily tested out right?
Yeah..i ran it i did'nt understand.. .please if you know help..
what do you actually mean by overflow? For what happen with a+b, the value stored in a and b cannot be greater than 2^32-1, so it will just store the modulo of 2^32. read this
for your updated question, it will be 4294967294 which is 2^32-2.as 2^32-1+2^32-1 = 2*(2^32) — 2 = -2 (mod 2^32)
Note that some languages (C and C++ are the most notable examples) include the notion of "undefined behavior", meaning that an experiment can be ill-defined and one cannot draw any conclusions from it.
Not for overflowing unsigned integers, though. If he knew about undefined behavior (I doubt it) but didn't know whether unsigned integer overflow was considered such, then google is a friend of his.