字符串處理——PAT 1024 科學計數法

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

 

思路:

將輸入存於string中,定位字符E的位置

E後爲‘-’    則刪除小數點,往前補指數個0,再將小數點插入第二位

E後爲‘+’   小數點往後移動指數位 

#include<iostream>
#include<string>
using namespace std;

int main()
{
	string a;//輸入
	string subA, subB;
	int indexE;//字符E的位置
	cin >> a;
	indexE =  a.find('E');
	subA = a.substr(1, indexE - 1);//底數
	subB = a.substr(indexE + 2);//指數
	int mul = stoi(subB);//將指數轉換爲int類型

	//指數爲負,表示很小的數
	if (a[indexE + 1] == '-')
	{
		subA.erase(1, 1);//底數刪除小數點
		subA.insert(0, mul, '0');//在0處插入mul(指數)個字符0
		subA.insert(1, 1, '.');//插入小數點
		if (a[0] == '-')
			subA.insert(0, 1, '-');//若爲負數,在開頭插入負號
		cout << subA;
	}

	//指數爲正,表示很大的數
	else if (a[indexE + 1] == '+')
	{
		subA.erase(1, 1);
		int len = subA.length();
		subA.append(mul - len + 1, '0');//在尾部補0
		if (a[0] == '-')
			subA.insert(0, 1, '-');//若爲負數,在開頭插入負號
		cout << subA;
	}

	system("pause");
	return 0;
}

 

當指數爲正時,不能直接補0,要判斷小數點向後移動的位數,可能還存在小數點

#include<iostream>
#include<string>
using namespace std;

int main()
{
	string a;//輸入
	string subA, subB;
	int indexE;//字符E的位置
	cin >> a;
	indexE =  a.find('E');
	subA = a.substr(1, indexE - 1);//底數
	subB = a.substr(indexE + 2);//指數
	int mul = stoi(subB);//將指數轉換爲int類型

	//指數爲負,表示很小的數
	if (a[indexE + 1] == '-')
	{
		subA.erase(1, 1);//底數刪除小數點
		subA.insert(0, mul, '0');//在0處插入mul(指數)個字符0
		subA.insert(1, 1, '.');//插入小數點
		if (a[0] == '-')
			subA.insert(0, 1, '-');//若爲負數,在開頭插入負號
		cout << subA;
	}

	//指數爲正,表示很大的數
	else if (a[indexE + 1] == '+')
	{
		subA.erase(1, 1);
		int len = subA.length();//底數的長度
		if (len - 1 > mul)//len-1表示小數點後的位數
			subA.insert(mul + 1, 1, '.');
		else
			subA.append(mul - len + 1, '0');//在尾部補0
		if (a[0] == '-')
			subA.insert(0, 1, '-');//若爲負數,在開頭插入負號
		cout << subA;
	}

	system("pause");
	return 0;
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章