python习题,小数形式转科学计数法

【问题描述】

编写一个程序,将用小数表示的浮点数,转换成科学计数法的形式输出。输入的数据没有符号,小数点前后必有数字,且全为有效数据,即小数点后的末尾数字不为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)




结果:

img

如果觉得答案对你有帮助,请点击下采纳,谢谢~