您的位置:首页 > 其它

PAT乙级1024. 科学计数法 (20)

2017-08-29 20:25 232 查看

题目链接

https://www.patest.cn/contests/pat-b-practise/1024

科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][1-9]"."[0-9]+E[+-][0-9]+,即数字的整数部分只有1位,小数部分至少有1位,该数字及其指数部分的正负号即使对正数也必定明确给出。

现以科学计数法的格式给出实数A,请编写程序按普通数字表示法输出A,并保证所有有效位都被保留。

输入格式:

每个输入包含1个测试用例,即一个以科学计数法表示的实数A。该数字的存储长度不超过9999字节,且其指数的绝对值不超过9999。

输出格式:

对每个测试用例,在一行中按普通数字表示法输出A,并保证所有有效位都被保留,包括末尾的0。
输入样例1:
+1.23400E-03

输出样例1:
0.00123400

输入样例2:
-1.2E+10

输出样例2:
-12000000000

思路分析

代码写的太长了,就不分析了---耗时间最多的一道题

还有

测试点4没有通过 /(ㄒoㄒ)/~~

代码

#include<iostream>
#include<cstring>
#include<iomanip>//控制输出格式
using namespace std;

int main()
{
//freopen("in.txt" , "r" , stdin) ;
char a[10001]={' '};
cin>>a;
char b[10001]={' '};
int t = 1;
if(a[0] == '-')
t = -1;
int dian = 2;
int i = 1,j = 0;
while(i < 10000)
{
if(a[i]=='E')
break;
if(a[i]=='.')
{
i++;
continue;
}
b[j] = a[i];
i++;
j++;
}
int c;
c = i - dian -1;
int mi = 0;
int tt = 1;
i++;
while(i < 10000)
{
if(a[i] == '-')
{
tt = -1;
i++;
continue;
}
if(a[i] == '+')
{
tt = 1;
i++;
continue;
}
if(a[i] < '0' ||a[i] > '9' )
break;
mi = 10*mi +(a[i] - '0');
i++;
}
mi = tt*mi;
int k;
k = mi - c;
if( k == 0)
puts(b);
if( k > 0)
{
if(t == -1)
cout<<'-';
for(int s = 0;s < k+c+1;s++)
{
if(s < 1+c)
cout<<b[s];
else
cout<<'0';
}
cout<<endl;
}
if( k < 0)
{
if(t == -1)
cout<<'-';
if(mi!=0)
{
for(int s = 0;s < 1-mi+c;s++)
{
if(s < (-mi))
{
cout<<'0';
if(s == 0)
cout<<".";
}
else
cout<<b[s+mi];
}
cout<<endl;
}
else
{
for(int s = 0;s < 1+c;s++)
{
cout<<b[s];
if(s == 0)
cout<<".";
}
cout<<endl;
}
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: