Go 中实现浮点除法与小数位控制(四舍五入到 4 位)

本文详解如何在 Go 中正确执行浮点除法,并使用格式化输出将结果精确控制为 4 位小数(自动四舍五入),避免整数除法导致的精度丢失。

本文详解如何在 Go 中正确执行浮点除法,并使用格式化输出将结果精确控制为 4 位小数(自动四舍五入),避免整数除法导致的精度丢失。

在 Go 中,int / int 运算默认执行整数除法,结果直接截断小数部分(非四舍五入),例如 190 / 13 得到 14,而非 14.6153...。这正是原代码输出错误结果的根本原因——即使变量名是 slope,q/w 仍是整型运算,float64(q)/float64(w) 才能触发浮点计算。

要获得带小数的精确商并四舍五入到 4 位,需两个关键步骤:

  1. 显式类型转换:将整数操作数转为 float64,确保除法按浮点规则执行;
  2. 格式化输出:使用 fmt.Printf("%.4f", value) 自动完成四舍五入并固定显示 4 位小数(末尾零不省略,如 14.6154)。

以下是修正后的完整可运行代码:

package main

import (
    "fmt"
    "bufio"
    "os"
    "strconv"
)

func main() {
    var xInp = bufio.NewScanner(os.Stdin)
    var yInp = bufio.NewScanner(os.Stdin)

    fmt.Print("insert y value: ")
    yInp.Scan()
    fmt.Print("insert x value: ")
    xInp.Scan()

    q, err := strconv.Atoi(yInp.Text())
    if err != nil {
        fmt.Println("error parsing y:", err)
        return
    }
    w, err := strconv.Atoi(xInp.Text())
    if err != nil {
        fmt.Println("error parsing x:", err)
        return
    }

    // ✅ 关键:转换为 float64 再除法
    slope := float64(q) / float64(w)

    // ✅ 关键:%.4f 自动四舍五入并保留 4 位小数
    fmt.Printf("%.4f\n", slope)
}

注意事项

通过这两处修改,程序即可准确输出 190/13 ≈ 14.6154,兼顾精度、可读性与 Go 的类型安全特性。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。