lsmCC 发表于 2023-12-1 20:45:17

为什么这样去最小值会报错

            ans=min(ans,(i-k+1));

FishC_GPT 发表于 2023-12-1 20:45:29

这种情况可能是因为你没有给`ans`一个初始值,导致在第一次比较时发生错误。正确的做法是在使用`min`函数之前给`ans`赋予一个足够大的初始值。

下面是一个示例代码:

ans = float('inf')# 给 ans 赋予一个足够大的初始值

for i in range(len(nums)):
    ans = min(ans, i - k + 1)

print(ans)

这里我们使用了`float('inf')`作为初始值,`inf`代表正无穷大,这样可以确保第一次比较时`ans`会被正确更新为`(i-k+1)`的值。如果在循环中没有找到更小的值,那么`ans`仍然会保持初始值`inf`。

以上回复来自 -- ChatGPT(FishC官方接口),如未能正确解答您的问题,请继续追问。

sfqxx 发表于 2023-12-1 21:06:31

没有看到完整的代码,所以只能做出一些大致的推测。这行代码本身不会导致错误,除非`ans`,`i`或`k`未被定义,或者它们的数据类型不允许进行这样的操作。

以下是可能的错误来源:

1. `ans`,`i`,`k`未定义:在调用这行代码之前,需要给`ans`,`i`和`k`赋值。

2. 数据类型错误:这行代码期待`ans`,`i`和`k`是可以进行加减及比较运算的数据类型。如果它们是无法进行这类操作的类型,如字符串(在某些编程语言中),则会导致错误。

3. 如果你在类或者函数中使用此行代码,但`ans`,`i`和`k`定义在类或者函数之外(全局变量),并且这门编程语言不支持在类或者函数内部直接使用全局变量,那么可能也会出现错误。

你可以按照错误提示来查看是哪种情况,调试你的代码。

求最佳答案{:10_254:}
页: [1]
查看完整版本: 为什么这样去最小值会报错