一、题目
二、代码
思路分析:
本题不能按照数学方法计算,因为牵扯到小数点的移动,题目要求还要保留所有的有效位,所以处理判断浮点型和整型特别麻烦
因此将该题目当做字符串来进行运算
注意:
需要注意的:num[0:0] 为空,int(’-03’) = -3 ,int(’+03’) = 3
# 以 E 来分隔前后的实数和指数
num,index = input().split('E')
num_flag = num[0] # 保留数字的符号位
num_int = num[1] + num[3:] # 去掉符号和小数点的数字部分
if int(index)<0:
# 这里加1 是因为表示小数点后几个0,比如10(-3),其实是0.00 + 一个数
x = int(index) + 1
num = '0' + '.' + '0'*abs(x) + num_int
else:
# 这里要比较 数字的小数部分和x 哪个位数长,关系到小数点的放置
# 这里之所以不用 x 与 len(num_int) -1 相比较,
#因为当 x 为0时,小数点应该移一位,但是 num[0:0]为空,所以 x 至少为1 ,代表至少存在一位整数
x = int(index) + 1
if x >=len(num_int): # 这里拿10的x次幂与 E num_int 的小数相比较
num = num_int + '0'*(x-len(num_int))
else:
num = num_int[0:x] + '.' + num_int[x:]
if num_flag == '-':
num = '-' + num
print(num)