鱼C论坛

 找回密码
 立即注册
查看: 3173|回复: 7

[已解决]傻瓜问题求助

[复制链接]
发表于 2022-10-12 16:45:09 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. #include <stdio.h>
  2. #include <math.h>

  3. int main()
  4. {
  5.         int ch;
  6.         long long num = 0;
  7.         long long temp; // 临时变量,用于测试是否超出范围
  8.         int is_overflow = 0;

  9.         const int max_int = pow(2, sizeof(int) * 8) / 2 - 1;
  10.         const int min_int = pow(2, sizeof(int) * 8) / 2 * (-1);

  11.         printf("请输入待转换的字符串:");

  12.         do
  13.         {
  14.                 ch = getchar();

  15.                 if (ch >= '0' && ch <= '9')
  16.                 {
  17.                         temp = 10 * num + (ch - '0');
  18.                         if (temp > max_int || temp < min_int)
  19.                         {
  20.                                 is_overflow = 1;
  21.                                 break;
  22.                         }
  23.                         else
  24.                         {
  25.                                 num = temp;
  26.                         }
  27.                 }
  28.                 else
  29.                 {
  30.                         if (num)
  31.                         {
  32.                                 break; // 如果已有数字,则退出循环
  33.                         }
  34.                 }

  35.         }
  36.         while (ch != '\n');

  37.         if (is_overflow)
  38.         {
  39.                 printf("数值超出范围,结果未定义!\n");
  40.         }
  41.         else
  42.         {
  43.                 if (!num)
  44.                 {
  45.                         printf("并未找到任何数值!\n");
  46.                 }
  47.                 else
  48.                 {
  49.                         printf("结果是:%d\n", num);
  50.                 }
  51.         }

  52.         return 0;
  53. }
复制代码

if(ch>='0'&&ch<='9')
                {
                        temp=10*num+(ch-'0');
                        if(temp>max_int||temp<min_int)
                        {
                                is_overflow=1;
                                break;
                        }
                        else
                        {
                                num=temp;
                        }
                }这是老师的代码
这串代码没看懂求解if(ch>='0'&&ch<='9')
                {
                        temp=10*num+(ch-'0');
                        if(temp>max_int||temp<min_int)
                        {
                                is_overflow=1;
                                break;
                        }
                        else
                        {
                                num=temp;
                        }
                }
最佳答案
2022-10-13 10:12:38
先领个币
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-10-12 17:13:36 | 显示全部楼层

回帖奖励 +2 鱼币

本帖最后由 jackz007 于 2022-10-12 19:41 编辑

          哪串代码没看懂,关于 overflow?
          看看什么才叫真正的溢出检测:
  1. #include <stdio.h>

  2. #define maxv 0x7fffffffffffffffLL
  3. #define minv 0x8000000000000000LL

  4. int overflow(long long d , char x)
  5. {
  6.         long long mv                                      ;
  7.         int r = 0                                         ;
  8.         if(d) {
  9.                 mv = (d > 0) ? maxv : minv                ;
  10.                 if(mv / d >= 10) {
  11.                         if(d > 0) {
  12.                                 if(mv - d * 10 < x) r = 1 ;
  13.                                 else r = 0                ;
  14.                         } else {
  15.                                 if(mv - d * 10 > x) r = 1 ;
  16.                                 else r = 0                ;
  17.                         }
  18.                 } else {
  19.                         r = 1                             ;
  20.                 }
  21.         }
  22.         return r                                          ;
  23. }

  24. int main(void)
  25. {
  26.         char ch                                           ;
  27.         long long num                                     ;
  28.         int c , s                                         ;
  29.         printf("maxv = %I64d\n" , maxv)                   ;
  30.         printf("minv = %I64d\n" , minv)                   ;
  31.         for(num = c = 0 , s = 1 ; (ch = getchar()) != '\n' ;) {
  32.                 if(ch >= '0' && ch <= '9') {
  33.                         ch -= '0'                         ;
  34.                         if(num < 0) ch = -ch              ;
  35.                         if(! overflow(num , ch)) {
  36.                                 num = num * 10 + ch       ;
  37.                         } else {
  38.                                 num = -1                  ;
  39.                                 break                     ;
  40.                         }
  41.                         if(num && s < 0) num = -num       ;
  42.                         c ++                              ;
  43.                 } else {
  44.                         if(s < 0) s = -s                  ;
  45.                         if(! c) {
  46.                                 if(ch == '-') s = - s     ;
  47.                         } else {
  48.                                 break                     ;
  49.                         }
  50.                 }
  51.         }
  52.         printf("%I64d\n" , num)                           ;
  53. }
复制代码

        编译、运行实况:
  1. D:\[00.Exerciese.2022]\C>g++ -o x x.c

  2. D:\[00.Exerciese.2022]\C>x
  3. maxv = 9223372036854775807
  4. minv = -9223372036854775808
  5. 9223372036854775807
  6. 9223372036854775807

  7. D:\[00.Exerciese.2022]\C>x
  8. maxv = 9223372036854775807
  9. minv = -9223372036854775808
  10. -9223372036854775808
  11. -9223372036854775808

  12. D:\[00.Exerciese.2022]\C>x
  13. maxv = 9223372036854775807
  14. minv = -9223372036854775808
  15. 9223372036854775808
  16. -1

  17. D:\[00.Exerciese.2022]\C>x
  18. maxv = 9223372036854775807
  19. minv = -9223372036854775808
  20. -9223372036854775809
  21. -1

  22. D:\[00.Exerciese.2022]\C>
复制代码

        后两次打印 -1 就是因为溢出
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-10-12 21:13:06 | 显示全部楼层

回帖奖励 +2 鱼币

?
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-10-13 00:40:09 | 显示全部楼层
if(ch>='0'&&ch<='9')
                {
                        temp=10*num+(ch-'0');
                        if(temp>max_int||temp<min_int)
                        {
                                is_overflow=1;
                                break;
                        }
                        else
                        {
                                num=temp;
                        }
                }   

这串代码 大佬们
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-10-13 07:55:03 | 显示全部楼层

回帖奖励 +2 鱼币

本帖最后由 jhq999 于 2022-10-13 08:19 编辑
  1. if(ch>='0'&&ch<='9')
  2.                 {
  3.                         temp=10*num+(ch-'0');//例如一个字符串“2341567825566”,num=0,temp=10*0+'2'-'0'=2,num=2,下一个temp=2*10+'3'-'0'=23以此类推,
  4.                                                         //直到234,156,782时,                       
  5.                         if(temp>max_int||temp<min_int)//再进一步‘5’时,就大于2,147,483,647(2^31-1)超出int类型正数范围,判断为溢出,负数判断temp<min_int也如此?
  6.                         {
  7.                                 is_overflow=1;
  8.                                 break;
  9.                         }
  10.                         else
  11.                         {
  12.                                 num=temp;
  13.                         }
  14.                 }   
复制代码

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2022-10-13 10:12:38 | 显示全部楼层    本楼为最佳答案   

回帖奖励 +2 鱼币

先领个币
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-10-13 10:13:26 | 显示全部楼层

回帖奖励 +2 鱼币

楼上说的很清楚了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-10-13 10:16:56 | 显示全部楼层

回帖奖励 +2 鱼币

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-24 18:20

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表