铛铛铛, 感觉这道题有点难,不过在抡蒙纂,瞎写之下居然过了,回顾一下加深印象😃
题目
1024 科学计数法 (20 分
科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式 [+-][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`
题解
看题分析一下
- 指数可以高达999,所以直接放弃使用数字表示,转而选用字符串或者直接输出结果(因为在输出的过程中不在涉及到输入), ok 我选择直接输出,方便点。
- 还有就是要保留所有有效位数,意思就是所有E之前的数字都要输出。
话不多说放代码
牛皮的C++
#include
#include
using namespace std;
int main()
{
string str;
cin>>str;
int e = str.find("E"); //找到E的位置
int index = 0; //指数大小
int zhi;//指数正负
if(str[e + 1] == '+') zhi = 1;
else zhi = -1;
for(int i = e + 2;i < str.size();i ++) //求指数
{
index = index * 10 + str[i] - '0';
}
if(str[0] == '-') cout<<'-';//如果为负直接输出符号
if(zhi < 0) //如果指数为负
{
cout<<"0."; //输出前导零
for(int i = 0;i
Happy everyday!