码迷,mamicode.com
首页 > 编程语言 > 详细

shell编程之冒泡排序

时间:2018-05-02 22:09:12      阅读:210      评论:0      收藏:0      [点我收藏+]

标签:之间   www.   div   必须   for-in循环   html   取数   循环控制   条件运算   

这是一个shell脚本的练手程序,练习for语句的使用

#! /bin/bash
n=0
while read arr[$n]  #通过键盘给数组赋值…数组首元素保存在arr[0]中……回车表示元素的输入间隔,Ctrl-d表示输入结束
do
   n=$[$n+1]
done              
#echo ${arr[*]}   #这是一个调试点,用来观察数组是否成功生成(如果成功,横着输出所有数组元素)

len=${#arr[*]}    #取数组长度

for((i=0;i<len;i++))    #冒泡排序算法…注意:for语句后面跟“双圆括号”
do
    for((j=0;j<len-i-1;j++))
    do
        t=$[$j+1]     #为了改进程序的可读性,使用变量t 来表示"arr(j+1)元素"
        if [[ ${arr[$j]}  -gt ${arr[$t]} ]]   #双方括号表示条件运算 与其中的表达式之间必须有空格,-gt表示大于
        #if [[ ${arr[$j]}  -gt ${arr[$[$j+1]} ]]  #这是 不使用变量t的写法,"arr(j+1)元素"有点不直观了
        then
              term=${arr[$j]}
              arr[$j]=${arr[$t]}
              arr[$t]=$term
        fi
    done
done

for((k=0;k<len;k++))  #排序结束之后,再按序输出数组元素
do
    echo ${arr[$k]}
done

脚本程序运行结果:

技术分享图片

说明:图中蓝色箭头上面的数字是用户输入(每输入一个数字 就敲一下回车,所有数字输入完毕之后 敲Ctrl+d 表示输入结束),蓝色箭头下面的数字是程序输出(是按从小到大的顺序排列的)

注:shell脚本,可以非常容易地实现“不定长数组”(即 声明数组的时候 可以不说明数组长度,而是根据用户的输入 “自动”的确定数组的长度,比如 用户输入十个数组 数组长度就是10),貌似C语言或者java不太容易实现这个…不定长数组,这样的东西可能是解释型语言的优点

 

shell脚本的for语句分两种:
一种是“遍历器”(即 for-in循环) 类似于java中foreach语句,在执行循环之前 先要有一个集合,循环执行的过程 就是遍历集合元素的过程……可以参考我写的《shell编程之99乘法表
一种就是“自动机”类似于C语言中for循环,需要描述循环的边界与步长……本文介绍的就是这种:关键字for后面跟双圆括号,其中使用循环控制变量来描述起始条件、终止条件和变量的变化(自增)规律……这与C语言的for循环是几乎一样的

 

 

shell编程之冒泡排序

标签:之间   www.   div   必须   for-in循环   html   取数   循环控制   条件运算   

原文地址:https://www.cnblogs.com/lionhear21st/p/8978052.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!