uva-465-Overflow

本文介绍了一种使用atof函数处理字符串到浮点数转换的方法,并通过一个具体的编程实例展示了如何判断输入数值是否超出预设的最大整数限制。讨论了在进行加法和乘法运算时,如何避免结果过大导致的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这道题目很扯啊,一开始看到的时候以为得用前面的题目的函数,写很长很长一段,但是,后来,我突然想起来,上次看王琳的博客有这道题目,代码很短,我好奇之下,一探究竟,发现竟然用atof函数,太扯淡了~我一开始还纳闷,既然double型的能够的话,为什么一开始不直接接受double型呢,还得用atof函数转换一下,后来,研究了研究,虽然double型的可以有那么长,但是直接输入的话,储存的不是原来的结果;

做这道题目给我的教训就是还是得多看看一些函数的应用啊~

 #include<stdio.h>
 #include<stdlib.h>
 #define max 2147483647
 int main()
 {
     char s1[10001],s2[10001],c;
     double x,y;
     while(scanf("%s %c %s",s1,&c,s2)!=EOF)
     {
         
         printf("%s %c %s\n",s1,c,s2);
         x=atof(s1);
         y=atof(s2);
         if(x>max)printf("first number too big\n");
         if(y>max)printf("second number too big\n");
         if(c=='+'&&x+y>max)printf("result too big\n");
         if(c=='*'&&x*y>max)printf("result too big\n");
     }
     return 0;
 }


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值