冒泡排序壳,没有输出

时间:2018-03-13 22:16:29

标签: arrays bash shell bubble-sort

我遇到了一个问题,我试图在shell中使用冒泡排序,我不确定我的问题出在哪里,因为我假设我的排序是正确的。我没有收到错误,但我根本没有对数字进行排序。

#!/bin/bash

array=( "$@" )
#echo ${array[@]} print all elements in the array

if [ $# -gt 9 ]
then
    echo Too many arguments, run the program over again
    exit
fi

j=0
flag=1
a=${#array[@]}

for((j=0;j < $a - 1 && flag==1 ;j++))
do
flag=0
for((i=0; i< $a-j-1; i++))
do
    x=${array[$i]}
    y=${array[$i+1]}
if ((x>y))
then
    flag=1
    export temp=$x 
    export x=$y 
    export y=$temp
fi
done
done

echo "Sorted Array: " ${array[@]}

1 个答案:

答案 0 :(得分:1)

正如评论中所指出的,您交换变量xy但从不交换任何数组条目。而不是

x=${array[$i]}
y=${array[$i+1]}
if ((x>y)); then
    flag=1
    export temp=$x 
    export x=$y 
    export y=$temp
fi

x=${array[$i]}
y=${array[$i+1]}
if ((x>y)); then
    flag=1
    array[$i]="$y"
    array[$i+1]="$x"
fi