冒泡排序

一、冒泡排序

通过对数据循环排序,得出数值大小,进行排序

二、排序过程

score =(10 5 1 100 70 60)
在这里插入图片描述

三、编写排序

1.脚本排序(脚本中设置的固定变量进行排序)

#!/bin/bash
# 冒泡排序
score=(10 5 1 100 70 60)
for ((i=1;i<${#score[*]};i++))
do
  for ((j=0;j<${#score[*]}-$i;j++))
  do
     if [ ${score[j]} -gt ${score[$(($j+1))]} ]
     then temp=${score[j]}       中间变量
         score[j]=${score[$(($j+1))]}
         score[$(($j+1))]=$temp
     fi
  done
done
echo ${score[*]}

此处[$(($j+1))]可以替换为[j+1]

2.在键盘上输入

[root@server2 ~]# vi maopao.sh
[root@server2 ~]# chmod +x maopao.sh 
[root@server2 ~]# ./maopao.sh 

#!/bin/bash
# 键盘输入冒泡排序
k=0                         数组第一位元素
while true                一直继续,循环
do
  read -p "是否需要输入数值?" do     变量名
  if [ $do == "no" ]   只要不输入no就一直继续
  then break            退出循环
  fi
  read -p "请输入第$(($k+1))个元素" key
  score[$k]=$key
  let k++
done

for ((i=1;i<${#score[*]};i++))
do
  for ((j=0;j<${#score[*]}-$i;j++))
  do
     if [ ${score[j]} -gt ${score[j+1]} ]
     then temp=${score[j]}
         score[j]=${score[j+1]}
         score[j+1]=$temp
     fi
  done
done
echo ${score[*]}

在这里插入图片描述

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值