【PAT (Basic Level) 】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

【注意点】:

  • 首先需要找到E的位置
  • E后面的指数可能为0
  • 当E后面是+号时,可能指数小于小数位数,也可能大于小数位数,也可能等于小数位数,在输出小数点时需要注意

【AC代码】:

#include 
#include 

using namespace std;

int main()
{
	string s;
	cin >> s;
	int i = 0, j;
	int sum = 0;
	for (i = 0; i < s.length(); i++)
	{
		if (s[i] == 'E')
		{
			for (j = i + 2; j < s.length(); j++)
			{
				sum = sum * 10 + (s[j] - '0');
			}
			if (s[0] == '-')
			{
				cout << '-';
			}
			if (sum == 0)//指数为0,输出原数
			{
				for (j = 1; j < i; j++)
				{
					cout << s[j];
				}
			}
			else//指数不为0
			{
				if (s[i + 1] == '+')//指数为正,扩大
				{
					cout << s[1];
					if (sum < i - 3)//小数位数比指数大,i-3表示有多少位小数
					{
						for (j = 3; j < 3 + sum; j++)
						{
							cout << s[j];
						}
						cout << ".";
						for (j = 3 + sum; j < i; j++)
						{
							cout << s[j];
						}
					}
					else//指数大于等于小数位数
					{
						for (j = 3; j < i; j++)
						{
							cout << s[j];
						}
						for (j = 1; j <= sum - (i - 3); j++)
						{
							cout << '0';
						}
					}
				}
				else//指数为负,缩小
				{
					cout << "0.";
					for (j = 1; j < sum; j++)
					{
						cout << '0';
					}
					cout << s[1];
					for (j = 3; j < i; j++)
					{
						cout << s[j];
					}
				}
			}
			return 0;
		}
	}
	return 0;
}

你可能感兴趣的:(PAT)