原因是
max通过将第一个值作为“到目前为止看到的最大值”,然后互相检查该值是否大于迄今为止看到的最大值来起作用。但是
nan,定义它是为了使与它的比较始终返回False
—
nan > 1即为false但
1 > nan也为false。
因此,如果您以
nan数组中的第一个值开头,则每个后续比较都将检查是否为
some_other_value >nan。这将始终是错误的,因此
nan将保留其位置为“到目前为止所能看到的最大值”。另一方面,如果
nan不是第一个值,那么当达到第一个值时,比较`nan
max_so_far
将再次为假。但是在这种情况下,这意味着当前的“到目前为止看到的最大值”(不是nan`)将保持到目前为止看到的最大值,因此nan将始终被丢弃。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)