我是 bash 脚本学习的新手,我很困惑如何编写这段代码。
array1=(23 34 23 12 11 32 12 12 12 21)
array2=(12 13 14 43 42 23 32 11 10 22)
这是两个数组,我需要获取元素的总和,例如 23+12、34+13 等,输出应该是Result 1: xx
数组中所有 10 个元素的(总和)。如何使用 C 样式循环对此进行编码?
答案1
这是另一个选择:
#!/bin/bash
array1=(23 34 23 12 11 32 12 12 12 21)
array2=(12 13 14 43 42 23 32 11 10 22)
for ((i = 0; i < ${#array1[@]} && i < ${#array2[@]}; i++)); do
printf "Result %2d: %d\n" $((i + 1)) $((array1[i] + array2[i]))
done
运行示例:
Result 1: 35
Result 2: 47
Result 3: 37
Result 4: 55
Result 5: 53
Result 6: 55
Result 7: 44
Result 8: 23
Result 9: 22
Result 10: 43
该脚本从 0 开始循环运行,直到最短数组的长度(以防万一将来的某些更改使一个数组比另一个数组长)。每次循环时,它都会打印第 i 个条目的结果。
答案2
也许是这样的?
array1=(23 34 23 12 11 32 12 12 12 21)
array2=(12 13 14 43 42 23 32 11 10 22)
# Declare array3 as an array
array3=()
for i in $( seq 1 $((${#array1[@]}+1)) ); do
array3+=( $(( ${array1[i]} + ${array2[i]} )) );
printf 'Result %d : %s\n' "$i" "${array3[i]}";
done
输出:
Result 1 : 47
Result 2 : 37
Result 3 : 55
Result 4 : 53
Result 5 : 55
Result 6 : 44
Result 7 : 23
Result 8 : 22
Result 9 : 43
答案3
array1=(23 34 23 12 11 32 12 12 12 21)
array2=(12 13 14 43 42 23 32 11 10 22)
set -- "${array1[@]}"
unset counter
for elem in "${array2[@]}"; do
set -- "$@" "$((++counter))" "$(( $1 + elem ))"
shift
done
printf 'Result %d: %d\n' "$@"
这将循环遍历其中一个数组(第二个)的所有元素,并且对于每个元素 ,$elem
它都会将一个计数器和总和添加到位置参数列表中。
总和是通过添加$elem
到第一个位置参数$1
(然后从列表中移出)来计算的。位置参数被初始化为第一个列表的元素,因此这有效地将元素配对。
循环之后,位置参数包含与总和配对的计数器值。然后用 打印这些printf
。
输出将是
Result 1: 35
Result 2: 47
Result 3: 37
Result 4: 55
Result 5: 53
Result 6: 55
Result 7: 44
Result 8: 23
Result 9: 22
Result 10: 43
显然,您也可以直接在循环中打印结果:
array1=(23 34 23 12 11 32 12 12 12 21)
array2=(12 13 14 43 42 23 32 11 10 22)
set -- "${array1[@]}"
unset counter
for elem in "${array2[@]}"; do
printf 'Result %d: %d\n' "$((++counter))" "$(( $1 + elem ))"
shift
done
使用 C 样式while
循环:
array1=(23 34 23 12 11 32 12 12 12 21)
array2=(12 13 14 43 42 23 32 11 10 22)
set -- "${array1[@]}"
unset counter
while [ "$#" -ne 0 ]; do
printf 'Result %d: %d\n' "$((++counter))" "$(( $1 + array2[counter-1] ))"
shift
done
一个纯粹的sh
变体:
set -- 23 34 23 12 11 32 12 12 12 21
unset counter
for elem in 12 13 14 43 42 23 32 11 10 22; do
printf 'Result %d: %d\n' "$((counter += 1))" "$(( $1 + elem ))"
shift
done
使用bc
和paste
:
array1=(23 34 23 12 11 32 12 12 12 21)
array2=(12 13 14 43 42 23 32 11 10 22)
paste -d '+' \
<( printf 'print "Result ", ++c, ": ", %s\n' "${array1[@]}" ) \
<( printf '%s, "\\n"\n' "${array2[@]}" ) |
bc
使用awk
(具有 C 风格for
循环!):
array1=(23 34 23 12 11 32 12 12 12 21)
array2=(12 13 14 43 42 23 32 11 10 22)
awk -v a="${array1[*]}" \
-v b="${array2[*]}" \
'
BEGIN {
split(a,aa," ");
n = split(b,bb," ");
for (i = 1; i <= n; ++i)
printf "Result %d: %d\n", i, aa[i]+bb[i]
}'
答案4
为了享受 dc 的乐趣
抱歉,评论是法语的。
#!/bin/bash
array1=(23 34 23 12 3211 32 12 2 12 21)
array2=(12 13 14 43 42 23 32 5 710 22)
dc <<EOF
# Definition
# macro e = quitter si les tableaux n ont pas la meme taille
# macro f = calcul du nb de digit du resultat et stocke le max dans registre p
# macro g = addition des tableaux dans le registre tableau m
# macro h = afficher les espaces pour le formattage
# macro i = affichage du resultat formatte
# registre j = nb elt tableau
# registre k = nb max de digit de l index du tableau
# registre l = compteur elt tableau
# registre m = tableau indexe de la somme des tableaux d entree
# registre n = compteur du nb de digit de l index du tableau
# registre o = nb max de digit pour affichage
# registre p = nb max de digit du calcul
# registre q = poubelle
# Strings
[arrays are not the same size]sa
[Result]sb
[:]sc
[ ]sd
# Macros
[lapq]se
[dZsp]sf
[ll;m+dZlp<fll:mll1-dsl0<g]sg
[lnd1+snldnlo>h]sh
[ll1+dddsllbndZsnlksolhxnlcn;mdZsnlpsolhxpsqlj>i]si
# Program
$(printf "%d\n" ${array1[*]})
zdsjZsk
$(printf "%d\n" ${array2[*]})
zlj-lj!=e
ljsllgxljsllgx
lix
EOF
展示 :
Result 1: 35
Result 2: 47
Result 3: 37
Result 4: 55
Result 5: 3253
Result 6: 55
Result 7: 44
Result 8: 7
Result 9: 722
Result 10: 43