乙级(Basic Level) 1014 科学计数法

题目描述

科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][1-9]"."[0-9]+E[+-][0-9]+,即数字的整数部分

只有1位,小数部分至少有1位,该数字及其指数部分的正负号即使对正数也必定明确给出。

现以科学计数法的格式给出实数A,请编写程序按普通数字表示法输出A,并保证所有有效位都被保留。

输入描述:

每个输入包含1个测试用例,即一个以科学计数法表示的实数A。该数字的存储长度不超过9999字节,且其指数的绝对值不超过9999。

输出描述:

对每个测试用例,在一行中按普通数字表示法输出A,并保证所有有效位都被保留,包括末尾的0。

输入例子:

+1.23400E-03

输出例子:

0.00123400

Python:
a = input().split('E') b = 1 if a[0][0]=='-': b = -1 a[0] = a[0][1:].replace('.','') if int(a[1])>=0: if int(a[1])<len(a[0])-1: a[0] = a[0][:int(a[1])+1]+'.'+a[0][int(a[0]):] else: a[0] = a[0] + '0'*(int(a[1])-len(a[0])+1) elif int(a[1])<0: a[0] = '0.'+(abs(int(a[1]))-1)*'0'+a[0] if b==-1: a[0] = '-'+a[0] print(a[0])

 

C++:
#include <iostream> using namespace std; int main() { int i,j,k=0; char a,b[20]; cin >> a; if (a == '-') cout << a; for (; k < 20;) { cin >> b[k++]; if (b[k - 1] == 'E') break; } k = k - 2; cin >> j; if (j >= 0) { cout << b[0]; if (j >= k - 1) { for (i = 2; i <= k; i++) cout << b[i]; for (i = 0; i < j - k + 1; i++) cout << '0'; } else { for (i = 0; i < j; i++) cout << b[i + 2]; cout << '.'; for (i = j + 2; i <= k; i++) cout << b[i]; } } else { cout << "0."; for (i = -1; i > j; i--) cout << '0'; for (i = 0; i <= k; i++) { if(b[i] != '.') cout << b[i]; } } return 0; }

 

posted @ 2018-08-18 12:36  黄冠积  阅读(159)  评论(0编辑  收藏  举报