【问题描述】
编写一个程序,将用小数表示的浮点数,转换成科学计数法的形式输出。输入的数据没有符号,小数点前后必有数字,且全为有效数据,即小数点后的末尾数字不为0;小数点前若只有一位数字,可以为0,否则小数点前的最高位数字不为0。
提示:以字符串形式保存相关数据。
【输入形式】
从控制台输入一小数,最后有回车换行符,所有输入的字符数不会超过100。
【输出形式】
以科学计数法形式输出数据。输出的数据由以下几部分构成:
1.底数部分是一个小数或整数,若为小数,则小数点前后必有数字,而且都为有效数字。即:小数点前只有一位大于0的数字,小数点后的末尾数字不能为0。若为整数,则只有一位数字,不带小数点。
2.必有小写字母e。
3.指数部分是一个整数,若大于等于0,则不带正号+。若小于0,则需要带负号-,且整数的最高位数字不为0。
【输入样例1】
0.000000000000002
【输出样例1】
2e-15
【输入样例2】
8.9845623489651700659
【输出样例2】
8.9845623489651700659e0
【输入样例3】
367298599999093453490394859509568659795603.4
【输出样例3】
3.672985999990934534903948595095686597956034e41
【样例说明】
以小数形式输入数据,然后转换成科学计数法形式输出。
l=input().split('.')
if int(l[0])>0:
p=len(l[0])-1
print(l[0][0]+'.'+l[0][1:]+l[1]+'e'+str(p))
else:
p=1
for i in l[1]:
if i == '0':
p+=1
else:
break
t=l[1][p-1:]
if len(t) > 1:
t=t[0]+'.'+t[1:]
print(t+'e-'+str(p))
number=float(input("请输入要处理的数据"))
if number>1:
i=0
if number<10:
print(str(number)+"e0")
if number>=10:
while number>10:
number=number/10
i=i+1
print(str(number)+"e"+str(i))
if number<1:
n=0
while number>1:
number=number*10
n=n+1
print(str(number)+"e-"+str(n))
a = input()
integerPart,floatPart = a.split(".")
# 首先是判断integerPart部分是不是0.
if integerPart == "0":
res1 = ""
b = 1
# 找到小数部分非零的位置
for index in range(len(floatPart)):
if floatPart[index] != "0":
b = str(index + 1)
break
res2 = floatPart[int(b)-1:]
res = res1 + res2 +"e" + "-" + b
else:
b = len(integerPart) - 1
res1 = integerPart[0] + "."
res2 = integerPart[1:] + floatPart
res = res1 + res2 + "e" + str(b)
print(res)
结果:
如果觉得答案对你有帮助,请点击下采纳,谢谢~