shell指令碼編程(快速排序)

來源:互聯網
上載者:User

標籤:

#!/bin/bash#shell指令碼編程之快速排序的實現(以最右邊為元點的思想)a=(8 5 10 3 2 93 4 1 2 3 40 9 61 8 6 29)#a=(0  0  0  0  1  2  3  3  4  4  8  28  30495  921  43716)temp=buff=#交換函數swap(){buff=${a[$1]}a[$1]=${a[$2]}a[$2]=$buff}fun(){i=$(($1-1))j=$1temp=${a[$2]}if test $1 -ge $2 ;thenreturn 2 fiwhile [ $j -le $2 ];do[ $j -lt $2 ] && while [[ ${a[$j]} -gt $temp ]] ;do j=$(($j+1))donei=$(($i+1))swap $i $jj=$(($j+1))done fun 0 $(($i-1)) fun $(($i+2)) $2}fun 0 15for((i=0;i<16;i++)){echo -n ${a[$i]} " "}echoexit 0

下面是C++快速排序的對照代碼

#include <iostream>using namespace std;void swap(int *a,int *b){int temp = *a;*a = *b;*b = temp;}void Grial(int a[],int x,int y){int i=x-1;int j=x;if(x>=y)return;int temp = a[y];while(j<=y){while(j<y&&a[j]>a[y])j++;i++;swap(&a[i],&a[j]);j++;}Grial(a,0,i-1);Grial(a,i+1,y);}int main(){int a[]={4,3,921,30495,28,43716,3,4,0,0,2,0,0,1,8,5};Grial(a,0,14);for(int i=0;i<15;i++){cout<<a[i]<<"  ";}cout<<endl;}


shell指令碼編程(快速排序)

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.