题目:
科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][1-9]"."[0-9]+E[+-][0-9]+,即数字的整数部分 只有1位,小数部分至少有1位,该数字及其指数部分的正负号即使对正数也必定明确给出。 现以科学计数法的格式给出实数A,请编写程序按普通数字表示法输出A,并保证所有有效位都被保留。
思路:这题开始时候觉得这题和组成原理的浮点数运算方式一样和麻烦,想想就忘了思路,参考以下别人的思路,发现只需根据指数移到小数点和补0就可以了。当指数小于0时,在左边补0,大于0判断是否小数点的位置超过了尾数的长度,超过才补0.需要注意的一点是,补0的个数条件的判断。
#include<iostream>
#include<cstdio>
#include<string>
#include<cstdlib>
using namespace std;
int main() {
// freopen("in.txt", "r", stdin); //+1.23400E-03 0.00123400
string str;
cin >> str;
if (str[0] == '-')cout << str[0]; //负数
int ea = str.find_last_of('E'); //e的位置
int index = atoi(str.substr(ea + 1).c_str()); //指数
string num = str.substr(1, ea - 1); //尾数
num.erase(1, 1); //去掉小数点
if (index < 0) {
num.insert(0, -index - 1, '0');
cout << "0." << num;
} else {
int len = num.length();
if (index < len - 1) {
num.insert(index + 1,1, '.');
} else if (index > len) {
num.insert(len, index + 1 - len, '0');
}
cout << num;
}
return 0;
}
这篇文章还有另外一个接收输入数据的方式:
1024 科学计数法 (20 分)_Eccentric_t的博客-CSDN博客
scanf("%c%c.%[0-9]E%d",&h,&a[0],a+1,&e);
%[] 的意思是:读入此集合所限定的那些字符。例如 %[A-Z] 是指接受大写字母,一旦遇到非大写字母便停止接受,而 %[^] 是指不要读入此集合所限定的那些字符。例如 % [^A-Z] 是指不接受大写字母,一旦遇到大写字母便停止接受。