1. 程式人生 > >1024 科學計數法

1024 科學計數法

科學計數法是科學家用來表示很大或很小的數字的一種方便的方法,其滿足正則表示式 [+-][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';
		}
	}
}