asthedeer 发表于 2020-2-12 01:09:03

S1E13作业中的小问题

请问 num为什么必须是long long 呢,我设为int的时候输入9999999999999结果不对,明明max_int是int嘛

#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;
}

人造人 发表于 2020-2-12 02:58:52

你能告诉我int的取值范围吗?

人造人 发表于 2020-2-12 03:18:09

抱歉,没有认真看题

问题是这行代码导致的
temp = 10 * num + (ch - '0');

如果num是int,这个表达式的值也是int
10 * num + (ch - '0')

举个例子,执行这条语句之前,num = 999999999,ch = '9'
执行完这条语句后temp不是9999999999,而是1410065407
因为这个表达式的结果是int,9999999999已经超过int的取值范围,把超出的部分丢掉,结果就是1410065407
10 * num + (ch - '0')

人造人 发表于 2020-2-12 03:21:54

可以这样把num强转成 long long
这样这个表达式的值就是 long long

temp = 10 * (long long)num + (ch - '0');


#include <stdio.h>
#include <math.h>

int main()
{
      int ch;
      int 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 * (long long)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;
}

asthedeer 发表于 2020-2-12 15:14:29

人造人 发表于 2020-2-12 03:18
抱歉,没有认真看题

问题是这行代码导致的


哦哦,明白了,谢谢大佬回答{:5_93:}
页: [1]
查看完整版本: S1E13作业中的小问题