1024 科学计数法

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/LightInDarkness/article/details/82724541

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

       如果输入样例的指数是负数,很简单;如果是整数就有些麻烦,需要考虑要不要输出小数点,如果不输出小数点还要补0的问题。一开始写的很麻烦,样例增多,发现错误也越来越难修改。于是整理了一下思路,重新写了部分代码,就通过了。写代码还是要带脑子的!

#include<iostream>

using namespace std;

int main(){
	string num, str_index;
	int i, int_index, flag = 0;
	cin >> num;
	str_index = num.substr(num.find('E') + 1, num.length() - num.find('E'));
	int_index = atoi(str_index.c_str());
	//输出负号
	if(num[0] == '-') cout << '-';
	//如果指数小于0 
	if(int_index < 0){
		cout << "0.";
		for(int j = 0; j < int_index * -1 - 1; j++) cout << '0';
	}
	for(int j = 1; num[j] != 'E'; j++){
		//输出小数点
		if(int_index < (num.find('E') - 3) && int_index >= 0){
			//在什么位置输出小数点 
			if(j == 3 + int_index){
				cout << '.';
				flag = 1;
			}
		}
		if(num[j] != '.') cout << num[j];
		//不输出小数点, 补0
		if(!flag && num[j + 1] == 'E'){
			for(int m = 0; m < int_index - j + 2; m++)
				cout << '0';
		}
	}
}

猜你喜欢

转载自blog.csdn.net/LightInDarkness/article/details/82724541
今日推荐