1024 科学计数法
题目:
科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式 [+-][1-9].
[0-9]+E[+-][0-9]+,即数字的整数部分只有 1 位,小数部分至少有 1 位,该数字及其指数部分的正负号即使对正数也必定明确给出。
现以科学计数法的格式给出实数 A,请编写程序按普通数字表示法输出 A,并保证所有有效位都被保留。
输入格式:
每个输入包含 1 个测试用例,即一个以科学计数法表示的实数 A。该数字的存储长度不超过 9999 字节,且其指数的绝对值不超过 9999。
输出格式:
对每个测试用例,在一行中按普通数字表示法输出 A,并保证所有有效位都被保留,包括末尾的 0。
输入样例 1:
1 | + 1 .23400E- 03 |
输出样例 1:
1 | 0.00123400 |
输入样例 2:
1 | - 1 .2E+ 10 |
输出样例 2:
1 | - 12000000000 |
思路:
测试点2、3始终过不了,最后发现是 指数刚好将前面小数变为整数的时候,小数点不应该输出。
代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | #include<stdio.h> #include<iostream> #include<string.h> using namespace std; int main(){ int i= 3 ,j= 1 ,e= 0 ,t= 1 ; char s1,s2,a[ 10005 ],s[ 10005 ]; cin>>a; s1 = a[ 0 ]; s[ 0 ] = a[ 1 ]; while (a[i] != 'E' ){ s[j++] = a[i++]; } s2 = a[++i]; for ( int k=strlen(a)- 1 ; k>i; k--){ e += (a[k] - '0' ) * t; t *= 10 ; } s1 == '-' ? cout<<s1 : cout<< "" ; if (s2 == '-' ){ cout<< "0." ; for ( int k= 1 ; k<e; k++){ cout<< "0" ; } for ( int k= 0 ; k<j; k++){ cout<<s[k]; } } else { if (j <= e){ for ( int k= 0 ; k<j; k++){ cout<<s[k]; } for ( int k=j; k<=e; k++){ cout<< "0" ; } } else { for ( int k= 0 ; k<=e; k++){ cout<<s[k]; } if (j > e+ 1 )cout<< "." ; for ( int k=e+ 1 ; k<j; k++){ cout<<s[k]; } } } return 0 ; } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通