Python,温度转换程序
毕业设计
1
请编写程序将用户输入华氏度转换为摄氏度,或将输入的摄氏度转换为华氏度。
转换算法如下:(C表示摄氏度、F表示华氏度)
C = ( F - 32 ) / 1.8
F = C * 1.8 + 32
要求如下:
- 输入输出的摄氏度采用大写字母C开头,温度可以是整数或小数,如:C12.34指摄氏度12.34度;
- 输入输出的华氏度采用大写字母F开头,温度可以是整数或小数,如:F87.65指摄氏度87.65度;
- 不考虑异常输入的问题,输出保留小数点后两位;
- 使用input()获得测试用例输入时,不要增加提示字符串
我的代码是
emp = input()
if temp[0] == 'C':
result = float('%.2f' % (float(temp[1:])*1.8+32))
print('F'+str(result))
elif temp[0] == 'F':
result = float('%.2f' % ((float(temp[1:])-32)/1.8))
print('C'+str(result))
出现的问题是:是能处理浮点数,输入整数时,输出就不能保留小数点后两位,可能是float(temp[1:])出错了,求解
如输入:F32
输出:C0.0
正确输出是:C0.00
-
temp = input("shuru:") if temp[0] == 'C': result = float('%.2f' % (float(temp[1:])*1.8+32)) print('F'+str(result)) elif temp[0] == 'F': result = '%.2f' % ((float(temp[1:])-32.00)/1.80) print('C'+str(result))
这条代码你原来写法是将 %.2f (此时已经是0.00了)然后你又加强制转换float()因为小数点后面是两个0 所以自动变成0.0只是说是浮点型 而不考虑小数位数,删去float即可。
代码如上,这样就ok了。
-
temp = "F32" if temp[0] == 'C': result = float('%.2f' % (float(temp[1:])*1.8+32)) print('F{:.2f}'.format(result)) elif temp[0] == 'F': result = float('%.2f' % ((float(temp[1:])-32)/1.8)) print('C{:.2f}'.format(result))
发表回复