方法1:
printf("%d\n",~(unsigned int)0/2);
当无符号0以二进制存储在内存中时,每一位都为0,以32位int为例,0(unsigned int)的二进制为:
00000000 00000000 00000000 00000000
按位取反(~)后变成:
11111111 11111111 11111111 11111111
此时的十进制为:
4294967295
除以2(int类型中有一半表示负数,且比正数多一个),得到:
2147483647
即为32位int型最大值
方法2:
#include <stdio.h>
int main()
{
int i=0,j=1;
while (j>0)
{
j++;
i++;
}
printf("%d\n",i);
printf("%d\n",j);
return 0;
}
整数值越界后符号改变
方法3:
#include <stdio.h>
int main()
{
int i=0;
i=~i;
i=i<<(sizeof(int)*8-1);
printf("%d\n",i);
i--;
printf("%d\n",i);
return 0;
}
计算机采用补码存储,先补码得到-1(即各位全为1),然后利用移位运算得到最小,进而得到最大。