您的位置:首页 > 编程语言 > C语言/C++

1024. 科学计数法 (20)

2016-06-01 14:14 274 查看

1024. 科学计数法 (20)

时间限制 100 ms

内存限制 65536 kB

代码长度限制 8000 B

判题程序 Standard

作者 HOU, Qiming

科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][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

原题地址: https://www.patest.cn/contests/pat-b-practise/1024

这道题刚开始没有看清楚,因为整数部分可以是0,,自己弄麻烦了,导致最后两个test没有过,今天看了别人的代码才明白,但也是测试了好久才过。

计算出小数部分的位数分清楚情况可以了

#include <iostream>
#include <algorithm>
#include <cmath>
#include <cstdio>
#include <cstring>
#include <cctype>
using namespace std;

char str[10000];

void solve()
{
char num[10000] = {0};  //去掉小数点后的数字串
int len = strchr(str, 'E') - str - 3;   //小数部分长度

num[0] = str[1];
strncpy(num + 1, str + 3, len);

int ex = atoi(str + len + 4);   //获取指数
int pos = 1;    //小数点位置

if(str[0] == '-')
cout << '-';

if(ex > 0){
pos += ex;
if(len < ex){
cout << num;
for(int i = len; i < ex; i ++)
cout << '0';
}
else if(len > ex){
for(int i = 0; i < pos; i ++)
cout << num[i];
cout << '.';
for(int i = pos; i < len + 1; i ++)
cout << num[i];
}
else{
cout << num;
}
}

else if(ex < 0)
{
cout << "0.";
for(int i = ex + 1; i < 0; i ++){
cout << '0';
}
for(int i = 0; i < len + 1; i ++)
cout << num[i];
}

else{
for(int i = 0; i < pos; i ++)
cout << num[i];
cout << '.';
for(int i = pos; i < len + 1; i ++)
cout << num[i];
}

cout << endl;
}

int main()
{
cin >> str;
solve();
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  pat c语言