本文介绍在算法竞赛场景下,使用 go 语言优雅、健壮地从标准输入读取指定数量的整数(或浮点数、字符串)的最佳实践,涵盖错误处理、作用域优化与循环结构设计。
在算法编程题中,常见输入格式为:首行给出数据个数 n,随后 n 行各含一个值(整数、浮点数或字符串)。原始代码虽能运行,但存在明显可优化点:for {} 无限循环逻辑冗余、未检查 fmt.Scanf 的返回错误、变量作用域过大、换行符处理不明确,且缺乏对输入异常的容错能力。
更推荐的写法是将循环条件、初始化与迭代逻辑统一收束至 for 语句头,并将临时变量(如 input)限制在最小作用域内。同时,必须检查 fmt.Scanf 返回的 error——因为竞赛环境输入可能意外中断(如 EOF、格式错误),忽略错误会导致程序 panic 或读取脏数据。
以下是优化后的标准模板(以整数为例):
package main
import "fmt"
func main() {
var count int
var err error
// 读取总数,注意 "%d\n" 显式消耗换行符,避免干扰后续读取
for _, err = fmt.Scanf("%d\n", &count); err == nil && count > 0; count-- {
var input int
_, err = fmt.Scanf("%d\n", &input)
if err != nil {
break // 输入提前终止,立即退出
}
// 此处可直接处理 input,或追加到切片
// 示例:num = append(num, input)
}
if err != nil && err != fmt.EOF {
panic("input error: " + err.Error())
}
}✅ 关键改进说明:
? 扩展提示:

掌握这一模式,能让你的算法代码既简洁又可靠,真正契合竞赛与工程双重需求。