1024 科学计数法 (20 分)

待我称王封你为后i 2023-10-01 19:12 125阅读 0赞

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

  1. #include<iostream>
  2. #include<bits/stdc++.h>
  3. #include<algorithm>
  4. #include<string>
  5. #include<stack>
  6. using namespace std;
  7. int main(){
  8. char h,a[10001]={
  9. 0};
  10. int i,e;
  11. scanf("%c%c.%[0-9]E%d",&h,&a[0],a+1,&e); //+ 1 . 234E -03
  12. if(h=='-')
  13. cout<<"-";
  14. if(e<0){
  15. cout<<"0.";
  16. e=-e-1;//3-1=2
  17. while(e>0){
  18. cout<<"0";
  19. e--;
  20. }
  21. cout<<a;
  22. }else{
  23. //-1.2E+10 - 1 . 2E +10
  24. for(i=0;i<=e||a[i]!=0;i++){
  25. if(i==e+1) cout<<".";//e+1=11
  26. printf("%c",a[i]==0?'0':a[i]);
  27. }
  28. }
  29. }

发表评论

表情:
评论列表 (有 0 条评论,125人围观)

还没有评论,来说两句吧...

相关阅读

    相关 1024 科学计数 java答案

    这道题有两种思路,一种是对字符数组处理后再逐个输出,也可以直接进行输出,下面答案采用后者方法,要注意的是最好用流来获取数据,如果用Scanner会超时 import