前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >冒泡排序法三部曲终极版の最优的冒泡排序算法

冒泡排序法三部曲终极版の最优的冒泡排序算法

作者头像
根究FPGA
发布2020-06-30 11:03:34
3680
发布2020-06-30 11:03:34
举报
文章被收录于专栏:根究FPGA根究FPGA

对于数组{1,2,5,9,4,10,13,59,30}每进行一次排序,右侧的有效位就会加一,可是在之前的两种方法中,每次小循环的比较次数依然是数组长度-1。

所以在最终优化版中,我们动态的修改每次小循环的次数,从而将冒泡排序法的速度提升到最快。

.h头文件

代码语言:javascript
复制
#pragma once
#ifndef _BUBBLE_H_
#define _BUBLE_H_
/*
 传入参数为数组地址
*/
void sort(int* array,int m) 
{
 printf("%d\n",m);
 int border = m-1;  //记录排序的边界,每次排序到此处
 for (int i = 0; i < m; i++)
 {
 int lastchange = 0;
 int sorted = 1;   //每次排序前默认数组已经有序
 for (int j = 0; j < border; j++)
 {
 if (array[j] < array[j + 1])
 {
 int temp = array[j];
 array[j] = array[j + 1];
 array[j + 1] = temp;
 sorted = 0;   //发生了元素交换则将sorted置0
 lastchange = j;  //记录最后一次发生交换的位置
 }
 }
 border = lastchange;
 if (sorted)
 {
 break;
 }
 }
}
#endif 

.c 主函数

代码语言:javascript
复制
#include<stdio.h>
#include"bubble.h"
int main()
{
 int x = 0;
 int array[] = {1,2,5,9,4,10,13,59,30};
 x = sizeof(array) / sizeof(int);
 sort(array,x);
 for (int m = 0; m < sizeof(array) / sizeof(int); m++)
 {
 printf("%d\t",array[m]);
 }
 return 0;
}

运行结果

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-09-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 根究FPGA 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档