为什么是布菲奥.当输入来自重定向时,NewReader不能正常工作



我目前正在CodeChef网站上尝试解决这一挑战,当手动输入时,我得到了问题中所述问题的预期答案。

但是当我尝试使用cat in.txt | go run my_program.go时,程序的输出是不同的。

正如您所看到的,我尝试使用fmt.Printf进行调试,但看起来bufio.NewReader随机错过了管道中的输入。

我想知道我做错了什么,以及是否有其他方法可以读取Golang中包含多个整数的整行。

谢谢你帮我

in.txt:的内容

4
3
1 2 3
3
3 2 1
3
0 0 0
3
1 3 2

手动输入时的正常输出:

1 1
3 3
1 1
1 2

使用cat in.txt | go run my_program.go输入文本时输出调试消息

debug <1 2 3
>
1 1
debug <>
1 1
debug <>
1 1
debug <>
1 1

我的程序:


package main
import (
"fmt"
"os"
"strings"
"bufio"
"strconv"
)
func main() {
t, n := 0, 0
fmt.Scanf("%d", &t)
for i := 0; i < t; i++ {
fmt.Scanf("%dn", &n)
v := make([]int, n)
rd := bufio.NewReader(os.Stdin)
text, _ := rd.ReadString('n')
fmt.Printf("debug <%s>n", text)
arr := strings.Split(strings.TrimSuffix(text, "n"), " ")
for k := 0; k < len(arr); k++ {
v[k], _ =  strconv.Atoi(arr[k])
}
fmt.Println(calc_intersect(v))
}
}
func calc_intersect(v []int) (int, int) {
smt, lgt := 100, 0
scenario := make([]int, len(v))
for sc := 0; sc < len(v); sc++  {
infect := make([]bool, len(v))
infect[sc] = true
scenario[sc] = simulate(v, infect)
}
for i := 0; i < len(scenario); i++ {
if scenario[i] <= smt {
smt = scenario[i]
}
if scenario[i] > lgt {
lgt = scenario[i]
}
}
return smt, lgt
}
func simulate(v []int, infect []bool) int {
var nb_inf int = 1
pos := make([]int, len(v))
for time := 0; time < 25; time++ {
for p := 0; p < len(v); p++ {
pos[p] = (v[p] * time) + p
}
for a := 0; a < len(v); a++ {
check_intersect(pos, infect, &nb_inf, a)
}
}
return nb_inf
}
func check_intersect(pos []int, infect []bool, nb_inf *int, a int) {
for b := 0; b < len(pos); b++ {
if a == b {
continue
}
if pos[a] == pos[b] && (infect[a] || infect[b]) && !(infect[a] && infect[b]) {
*nb_inf += 1
infect[a], infect[b] = true, true
}
}
}

您对bufio.NewReader的使用是错误的。每次通过i循环创建一个新的缓冲读卡器。如果输入可用,读取器可以提前读取,并且当您不重用读取器时,缓冲的输入是未使用的。

只需将rd := bufio.NewReader(os.Stdin)移出循环即可解决问题。

当您通过stdin从控制台读取时,您的代码可以工作,因为您的键入速度不够快,读取器无法尝试缓冲输入。

最新更新