我在 bash 中有一个数组。例如
array=(1 3 4e-10 6 4 2e-4 7 5 2 9)
我想知道如何返回最小数字的位置,在本例中为 3。
尝试这个:
arr=(1 3 4e-10 6 4 2e-4 7 5 2 9)
对于最小值和位置
echo "${arr[@]}" | tr -s ' ' '\n' | awk '{print($0" "NR)}' |
sort -g -k1,1 | head -1
4e-10 3
对于最小值的位置
echo "${arr[@]}" | tr -s ' ' '\n' | awk '{print($0" "NR)}' |
sort -g -k1,1 | head -1 | cut -f2 -d' '
3
$ array=(1 3 4e-10 6 4 2e-4 7 5 2 9)
$ echo "${array[*]}" | tr ' ' '\n' | awk 'NR==1{min=$0}NR>1 && $1<min{min=$1;pos=NR}END{print min,pos}'
4e-10 3
要不就
$ echo "${array[*]}" | tr ' ' '\n' | awk 'NR==1{min=$0}NR>1 && $1<min{min=$1;pos=NR}END{print pos}'
3
只是为了获得位置。
就像评论说的那样,Bash 不做浮点数。我会遍历数组并使用 perl 或 awk。像这样的东西应该工作:
for i in ${array[@]}; do echo $i; done | perl -e 'use strict; my @array; while(<STDIN>) { chomp $_; push (@array,$_+0); } foreach my $number (sort {$a <=> $b} @array) { print "$number\n"; } '
bash 和 perl 的一个非常“线路嘈杂”的组合
array=(1 3 4e-10 6 4 2e-4 7 5 2 9)
perl -lanE '
say 1 + (sort {$a->[1] <=> $b->[1]} map {[$_, $F[$_]]} 0..$#F)[0]->[0]
' <<< "${array[@]}"
输出3