percy213 发表于 2023-8-16 11:52:17

课后题求助

5. 如果给 int() 函数传入一个浮点数参数,那么 int() 是简单暴力地将小数部分裁掉(比如 int(9.99) 的结果等于 9)……可是我们更习惯的是使用“四舍五入”的方式来取整。如果不借助其它函数,你能够单纯使用 int() 函数来实现吗?

使用代码:
x=input()
if int(x)>5:
    int(x)=int(x)+1
y=int(x)
print(y)
报错,求助,谢谢

isdkz 发表于 2023-8-16 11:52:42

问题出在第四行的赋值语句上。在Python中,不能将值赋给一个函数调用的结果,即使这个函数是内置函数。所以不能直接将int(x)的结果赋值给int(x)+1 。

要实现四舍五入的取整方式,可以使用以下代码:

x = input()
if int(x) > 5:
    x = str(int(x) + 1)
else:
    x = str(int(x))
print(x)


这里使用了一个条件语句来判断小数部分是否大于5,如果大于5,则将整数部分加1,然后将结果转换为字符串进行输出。如果小于等于5,则直接将整数部分转换为字符串进行输出。这样就实现了四舍五入的取整方式。

smallwh 发表于 2023-8-16 12:56:27

#只考虑正数
x = input()
dot = x.find('.')#不确定小数点的位置,所以先获取小数点的索引
if dot != -1 and int(x) > 4:
    #如果有小数点并且后一位大于4
    y = int(float(x)) + 1#直接int()会报错,因为字符串中可能是个小数
else:
    y = int(float(x))
print(y)
这一小段代码只考虑正数的情况,能够满足四舍五入的要求
但是,int函数在浮点数参数小于0时,结果会更靠近0
所以如果也要实现负数,可以选下面的代码:
x = input()
dot = x.find('.')
if dot != -1 and int(x) > 4 and float(x) > 0:
    y = int(float(x)) + 1
elif dot != -1 and int(x) > 4 and float(x) < 0:
    y = int(float(x)) - 1
else:
    y = int(float(x))
print(y)

percy213 发表于 2023-8-16 15:42:43

isdkz 发表于 2023-8-16 11:52
问题出在第四行的赋值语句上。在Python中,不能将值赋给一个函数调用的结果,即使这个函数是内置函数。所以 ...

但是还是运行不了,报错啊,谢谢
页: [1]
查看完整版本: 课后题求助