PAT乙级 1024. 科学计数法 (20)
2016-12-08 15:08
183 查看
科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][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
#将输入分两部分处理,将E前部分去掉小数点放入字符串中,求出小数部分长度。剩下就是对指数符号讨论,然后分析什么位置该输出小数点。
#include <iostream> #include <string.h> #include <math.h> #include <stdlib.h> using namespace std; int main() { char str[10008]={0}; cin>>str; int E; char N[10008]={0}; int epos = strchr(str,'E')-str; E= atoi(str+epos+1); int len = epos-3; N[0] = str[1]; strncpy(N+1,str+3,epos-3); if(str[0]=='-') cout<<"-"; if(E<0) { cout<<"0."; for(int i=0;i<-E-1;i++) cout<<"0"; cout<<N; } else if(E>0) { if(len<=E) { cout<<N; for(int i=0;i<E-len;i++) cout<<"0"; } else{ for(int i=0;i<E+1;i++) cout<<N[i]; cout<<"."; cout<<N+E+1; } } else { cout<<N[0]; cout<<"."; cout<<N+2; } return 0; }
相关文章推荐
- PAT乙级—1024. 科学计数法 (20)-native
- 1024. 科学计数法 (20)(PAT乙级题库)
- PAT乙级(中文)1024. 科学计数法 (20)
- 【PAT】(乙级)1024. 科学计数法 (20)
- PAT 乙级 1024. 科学计数法 (20)
- 1024. 科学计数法 (20)-PAT乙级真题
- PAT乙级 1024. 科学计数法 (20)--字符串的分割和移位
- 1024. 科学计数法 (20) PAT乙级真题
- PAT乙级1024. 科学计数法 (20)
- pat乙级真题:1024. 科学计数法 (20)
- [PAT乙级]1024. 科学计数法 (20)
- 浙江大学PAT_乙级_1024. 科学计数法 (20)
- PAT 乙级练习题1024. 科学计数法 (20)
- PAT乙级 1024. 科学计数法 (20)
- PAT 乙级 1024. 科学计数法 (20)
- 1024. 科学计数法 (20)--PAT乙级
- PAT-乙级-1024. *科学计数法 (20)
- PAT-乙级-1024. 科学计数法 (20)
- PAT乙级.1024. 科学计数法 (20)
- pat 乙级 1024. 科学计数法 (20)