猪猪虾 发表于 2020-6-19 09:52:49

C语言13讲,23行语句实现什么功能

//将用户输入的字符串中代表数字的字符转换为整型数值
// 打印转换结果
//只打印第一组数字
//如果字符串中不存在任何表示数值的字符,则打印“并未找到任何数值”
// 检测数值是否超出整型变量(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;
}

jackz007 发表于 2020-6-19 10:28:32

本帖最后由 jackz007 于 2020-6-19 10:39 编辑

      实际计算前,预测新的 num 数值是否超出整型数的可表达范围,因为 num、temp 的类型都是 long long,可表达数值范围要大于 int,所以,完全有条件来做这个判断。

猪猪虾 发表于 2020-6-19 11:00:15

jackz007 发表于 2020-6-19 10:28
实际计算前,预测新的 num 数值是否超出整型数的可表达范围,因为 num、temp 的类型都是 long long ...

temp = 10 * num + (ch - '0');这句,我没懂,num*10是干啥,还ch -'0'

jackz007 发表于 2020-6-19 11:28:40

本帖最后由 jackz007 于 2020-6-19 11:46 编辑

猪猪虾 发表于 2020-6-19 11:00
temp = 10 * num + (ch - '0');这句,我没懂,num*10是干啥,还ch -'0'

         ch - '0' 是把字符变成数值的操作,例如,如果 ch = '9',那么,字符 '9' 对应的 ASCII 编码是 57,字符 '0' 对应的 ASCII 编码是 48,那么,ch - '0' = 57 - 48 = 9 于是,我们通过这种办法就可以从字符 '9' 中提取到它所代表的数值 9 了。

         假如你键入了 '358' 那么,程序将会循环 3 次分别对三个字符进行处理,三次循环中,ch 将依次等于 '3'、'5'、'8'
         ch = '3' , num = 0 :
                     num = mun × 10 + ch - '0' = 0 * 10 + '3' - '0' = 3
         ch = '5' ,num = 3:
                     num = mun × 10 + ch - '0' = 3 * 10 + '5' - '0' = 35
         ch = '8' , num = 35 :
                     num = mun × 10 + ch - '0' = 35 * 10 + '8' - '0' = 358
      于是,你从键盘输入的字符 '358' 就这样被变成了整型数 358

jackz007 发表于 2020-6-19 11:34:07

你的代码应该不合格,因为它不能接受处理负值输入,试试我的代码吧:
#include <stdio.h>

main()
{
      int maxint = 0x7fffffff , minint = 0x80000000 , num = 0 , count = 0                      ;
      char ch                                                                                  ;
      bool overflow = false , neg = false                                                      ;
      printf("minint = %d , maxint = %d\n\n" , minint , maxint)                              ;
      printf("请输入数字 : ")                                                                  ;
      while((ch = getchar()) != '\n') {
                if (ch >= '0' && ch <= '9') {
                        if (! neg) {
                              if ((maxint - (ch - '0')) / 10 >= num) num = num * 10 + ch - '0' ;
                              else overflow = true                                             ;
                        } else {
                              if ((minint + (ch - '0')) / 10 <= num) num = num * 10 - ch + '0' ;
                              else overflow = true                                             ;
                        }
                        if (overflow) break                                                      ;
                        count ++                                                               ;
                } else if (ch == '-' && ! count) neg = true                                    ;
                else break                                                                     ;
      }
      if (count) {
            if (! overflow) printf("%d\n" , num)                                                 ;
            else printf("数值超出范围,结果未定义!\n")                                           ;
      } else printf("并未找到任何数值!\n")                                                   ;
}
      完全不用定义 long long 型数据,只要数值超出,立即就能检测到。
页: [1]
查看完整版本: C语言13讲,23行语句实现什么功能