这道题是一道伪高精度题,用double就行,不需要用大数加法和乘法,当然你也可以
用大数写,注意这道题中atof函数的用法:
atof(将字串转换成
浮点型数)
表头文件 #include <stdlib.h>
定义函数 double atof(const char *nptr);
函数说明 atof()会扫描参数nptr
字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时('\0')才结束转换,并将结果返回。参数nptr字符串可包含正负号、小数点或E(e)来表示指数部分,如123.456或123e-2。
返回值 返回转换后的
浮点型数。
附加说明 atof()与使用
strtod(nptr,(char**)NULL)结果相同。
范例 /* 将字符串a 与字符串b转换成数字后相加*/
|
1
2
3
4
5
6
7
8
9
10
|
#include<stdlib.h>
intmain()
{
char
*a=
"-100.23"
;
char
*b=
"200e-2"
;
doublec;
c=
atof
(a)+
atof
(b);
printf
(“c=%.2lf\n”,c);
return0;
}
|
执行 c=-98.23
贴上本题代码:
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<cctype>
#include<cstdlib>
#include<cmath>
#define MAX 2147483647
using namespace std;
char num1[300],num2[300];
int main()
{
char c;
while(scanf("%s %c %s",num1,&c,num2)!=EOF)
{
printf("%s %c %s\n",num1,c,num2);
double a,b;
a=atof(num1);
b=atof(num2);
if(a>MAX) printf("first number too big\n");
if(b>MAX) printf("second number too big\n");
if(c=='+'&&a+b>MAX) printf("result too big\n");
if(c=='*'&&a*b>MAX) printf("result too big\n");
}
return 0;
}
本文详细介绍了如何使用atof函数将字符串转换为浮点数,并通过实例演示了其在数学计算中的应用,同时提供了注意事项。
1584

被折叠的 条评论
为什么被折叠?



