尝试做测验“网格中 2 的最大和”
无法弄清楚如何解决以下错误。
感觉好像我错过了一些东西。一旦我找到了我可以更新的问题,使其更加普遍并且可能适用于其他人。
Line 32: value too great for base (error token is "08")
#!/bin/bash
setup () {
grid=(01 02 03 04 05 06 07 08 07 06 05
12 13 14 15 16 15 14 13 12 11 11
05 06 06 07 07 07 06 06 05 05 04)
n=${#grid[@]}
number_of_lines=$((n / 11))
length_of_line=$1
largest_sum=0
largest_pos=0
}
largest_2 () {
for ((row=0; row < number_of_lines; row++)) {
for ((column=0; column<length_of_line-1; column++)) {
larger_horizontal
if [[ $row -lt $number_of_lines-1 ]]; then
larger_vertical
fi
}
}
}
larger_vertical () {
sum=$((grid[column+row*11]*grid[column+(row+1*11)]))
if [[ $sum -gt $largest_sum ]]; then
largest_sum=$sum
largest_pos=$((column+row*11))
direction=vertical
result=$largest_pos
fi
}
larger_horizontal () {
sum=$((grid[column+(row*11)]*grid[column+1+(row*11)])) # <-- Line 32
if [[ $sum -gt $largest_sum ]]; then
largest_sum=$sum
largest_pos=$((column+(row*11)))
direction=horizontal
result=$largest_pos
fi
}
setup 11
largest_2
printf "\n1. Max: row=$((result / 11 +1)) column= $((result % 11 +1)) direction=$direction\n"
答案1
08
以 0 开头,因此在某些情况下被视为八进制(数字在 0 到 7 之间,因此错误从 开始08
)。解决办法:过滤掉0;如果你需要输出前导 0,有printf %02d
.