冒泡排序(C、Python)

BEGIN:

1、冒泡排序思想(升序排序):

如 a=[9,6,8,7,5,3]

i=0

第一趟排序:3与5比较,3和5交换位置,a=[9,6,8,7,3,5]; j=len-1

      3与7比较,3和7交换位置,a=[9,6,8,3,7,5]; j=len-2

      3与8比较,3和8交换位置,a=[9,6,3,8,7,5]; j=len-3

      3与6比较,3和6交换位置,a=[9,3,6,8,7,5]; j=len-4

      3与9比较,3和9交换位置,a=[3,9,6,8,7,5]; j=len-5=i

      第一趟排序结束,此时3在正确的位置上,a=[3,9,6,8,7,5]

i=1

第二趟排序:5与7比较,5和7交换位置,a=[3,9,6,8,5,7]; j=len-1

      5与8比较,5和8交换位置,a=[3,9,6,5,8,7]; j=len-2

      5与6比较,5和6交换位置,a=[3,9,5,6,8,7]; j=len-3

      5与9比较,5和9交换位置,a=[3,5,9,6,8,7]; j=len-4=i

      第二趟排序结束,此时3和5在正确的位置上,a=[3,5,9,6,8,7]

i=2

第三趟排序:7与8比较,7和8交换位置,a=[3,5,9,6,7,8]; j=len-1

      7与6比较,不用交换位置,a=[3,5,9,6,7,8]; j=len-2

      6与9比较,6和9交换位置,a=[3,5,6,9,7,8]; j=len-3=i

      第三趟排序结束,此时3、5、6在正确的位置上,a=[3,5,6,9,7,8]

i=3

第四趟排序:8与7比较,不用交换位置,a=[3,5,6,9,7,8]; j=len-1

      7与9比较,7和9交换位置,a=[3,5,6,7,9,8]; j=len-2=i

      第四趟排序结束,此时3、5、6、7在正确的位置上,a=[3,5,6,7,9,8]

i=4

第五趟排序:8与9比较,8和9交换位置,a=[3,5,6,7,8,9]; j=len-1=i

      第五趟排序结束,此时所有数字都在正确的位置上,a=[3,5,6,7,9,8]

冒泡排序结束。

代码:

C语言:

 

数字冒泡排序

#include<stdio.h>

#字符串冒泡排序
void Bubble(int s[], int len){
    int i,j;
    for(i=0;i<len-1;i++){
        int f=1;
        for(j=len-1;j>i;j--){
            if(s[j-1]>s[j]){
                char t=s[j];
                s[j]=s[j-1];
                s[j-1]=t;
            }
        }
        if(f){
            break;
        }       
    }
}

int main(){
    int  a[]={9,6,8,7,5,3};
    len = sizeof(a)/sizeof(a[0]);
    Bubble(a,len);
    for(int i=0;i<len;i++){
        printf("%d",a[i]);
    }
    printf("\n");
    return 0;
}

字符串冒泡排序

#include<stdio.h>
#include<string.h>

#字符串冒泡排序
void Bubble(int s[], int len){
    int i,j;
    for(i=0;i<len-1;i++){
        int f=1;
        for(j=len-1;j>i;j--){
            if(s[j-1]>s[j]){
                char t=s[j];
                s[j]=s[j-1];
                s[j-1]=t;
            }
        }
        if(f){
            break;
        }       
    }
}

int main(){
    char  s[1024];
    scanf("%s",s);
    len = strlen(s);
    Bubble(s,len);
    printf("%s\n",s);
    return 0;
}

Python:

数字冒泡排序:

def Bubble(a):
    n = len(a)
    for i in range(n-1):
        f=True
        for j in range(n-1,i,-1):
            if a[j]<a[j-1]:
                t = a[j]
                a[j]=a[j-1]
                a[j-1]=t
                f=False
        if f:break
    return a

def solution():
    a=[9,6,8,7,5,3]
    a=Bubble(a)
    for k in a:
        print(k,end=(' '))
    print()

END.

posted @ 2020-11-09 11:46  Gangpei  阅读(120)  评论(0编辑  收藏  举报