
我想显示切片中正数、负数和零元素的比率。我需要 float32 格式的比率。这是我的代码:
arr := []int32{-2, -1, 0, 1, 2}
var negativenumber, positivenumber, zeronumber, totalnumber int32
var negativeratio, positiveratio, zeroratio float32
for i := 0; i < len(arr); i++ {
totalnumber += 1
}
for i := 0; i < len(arr); i++ {
if arr[i] < 0 {
negativenumber += 1
} else if arr[i] == 0 {
zeronumber += 1
} else if arr[i] > 0 {
positivenumber += 1
}
}
negativeratio = float32(negativenumber / totalnumber)
zeroratio = float32(zeronumber / totalnumber)
positiveratio = float32(positivenumber / totalnumber)
fmt.printf("total number: %d\n", totalnumber)
fmt.printf("positive number: %d\n", positivenumber)
fmt.printf("negative number: %d\n", negativenumber)
fmt.printf("zero number: %d\n", zeronumber)
fmt.printf("positive ratio: %f\n", positiveratio)
fmt.printf("negative ratio: %f\n", negativeratio)
fmt.printf("zero ratio: %f\n", zeroratio)但是,当我打印变量时,我得到的正数、负数和零数是正确的,但比率是错误的。这是输出:
total number: 5 positive number: 2 negative number: 2 zero number: 1 positive ratio: 0.000000 negative ratio: 0.000000 zero ratio: 0.000000
我做错了什么?
您使用的是整数除法而不是浮点除法,浮点除法会丢弃余数并仅返回除法结果的整数部分。
由于 negativeNumber 和 totalNumber 都是 int32 类型,因此 NegativeNumber /totalNumber 执行整数除法,即执行除法并返回结果的下限(即 0)。然后,当您使用 float32(负数/总数) 将其转换为 float32 时,您会得到 0.0,这是预期的。
为了使用浮点除法,操作数之一必须是浮点类型。为此,您可以使用:float32(负数)/totalNumber
以上就是Go - 切片中正数、负数和零数元素的比率的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号