数据结构之冒泡排序

2019-05-28  本文已影响0人  townof1997

冒泡排序的思想
1,比较相邻的元素,如果第一个比第二个大,就交换他们两个
2,对每一对相邻的元素做同样的工作,从开始的第一对到结尾的最后一对,在这一点最后的元素应该是最大数
3,针对所有的元素,重复以上的步骤
4,持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较
算法稳定性

void Bobble_Sort(int a[], int n)
{
    int i,j,temp;
    for(j = 0; j < n - 1; j++)
    {
        for(i = 0; i < n - 1 - j; i++)
        {
            if(a[i] > a[i+1])
            {
                temp = a[i];
                a[i] = a[i+1];
                a[i+1] = temp;
            }
        }
    }
 } 

完整代码如下:

#include <stdio.h>
#include <stdlib.h>
#define SIZE 10
void Bobble_Sort(int a[], int n)
{
    int i,j,temp;
    for(j = 0; j < n - 1; j++)
    {
        for(i = 0; i < n - 1 - j; i++)
        {
            if(a[i] > a[i+1])
            {
                temp = a[i];
                a[i] = a[i+1];
                a[i+1] = temp;
            }
        }
    }
 } 
int main()
{
    int a[SIZE] = {65,15,21,45,32,16,30,98,78,22};
    int i = 0;
    int j = 0;
    printf("排序之前的结果:\n");
    for (i = 0;i < SIZE;i++)
    {
        printf("%4d",a[i]);
    }
    printf("\n");
    Bobble_Sort(a,SIZE);
    printf("排序之后的结果:\n");
    for (j = 0;j < SIZE;j++)
    {
        printf("%4d",a[j]);
    }
    printf("\n");
    return 0;
 } 
上一篇 下一篇

猜你喜欢

热点阅读