| 
 | 
 
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册  
 
x
 
为什么最大是pow(2, sizeof(int) * 8) / 2 - 1这样? 
为什么最小是pow(2, sizeof(int) * 8) / 2 * (-1)这样? 
 
题目: 
A. 如果字符串中不存在任何表示数值的字符,则打印“并未找到任何数值” 
B. 检测数值是否超出整型变量(int)可存放的范围,如果超出范围,则打印“数值超出范围,结果未定义!”的提醒。 
C. 为了达到锻炼的效果,整型变量的范围需要自己计算,不使用 <limits.h> 头文件。 
代码答案: 
#include <stdio.h> 
#include <math.h> 
 
int main() 
{ 
        int ch; 
        long long num = 0; 
        long long temp; // 临时变量,用于测试是否超出范围 
        int is_overflow = 0; 
 
        const int max_int = pow(2, sizeof(int) * 8) / 2 - 1; 
        const int min_int = pow(2, sizeof(int) * 8) / 2 * (-1); 
 
        printf("请输入待转换的字符串:"); 
 
        do 
        { 
                ch = getchar(); 
 
                if (ch >= '0' && ch <= '9') 
                { 
                        temp = 10 * num + (ch - '0'); 
                        if (temp > max_int || temp < min_int) 
                        { 
                                is_overflow = 1; 
                                break; 
                        } 
                        else 
                        { 
                                num = temp; 
                        } 
                } 
                else 
                { 
                        if (num) 
                        { 
                                break; // 如果已有数字,则退出循环 
                        } 
                } 
 
        } 
        while (ch != '\n'); 
 
        if (is_overflow) 
        { 
                printf("数值超出范围,结果未定义!\n"); 
        } 
        else 
        { 
                if (!num) 
                { 
                        printf("并未找到任何数值!\n"); 
                } 
                else 
                { 
                        printf("结果是:%d\n", num); 
                } 
        } 
 
        return 0; 
}
这里的式子是为了计算int类型的最大值和最小值。int类型的大小是根据不同的编译器和操作系统而定的,一般情况下是4个字节(32位),也就是32位二进制数,所以最大值就是所有位都是1,最小值就是所有位都是0,但是由于最高位是符号位,所以最大值要除以2,最小值要乘以-1。因此,pow(2, sizeof(int) * 8) / 2 - 1就是int类型的最大值,pow(2, sizeof(int) * 8) / 2 * (-1)就是int类型的最小值。其中,sizeof(int) * 8是计算int类型的位数,pow(2, sizeof(int) * 8)是计算int类型的取值范围。 
 
 
 |   
 
 
 
 |