在C语言中,常用的排序算法有:冒泡排序、快速排序、插入排序、选择排序、希尔排序、堆排序以及归并排序等等.

  冒泡排序基本概念:  依次比较相邻的两个数,将小数放在前面,大数放在后面。

 #include <stdio.h>
#include <stdlib.h>
#include <time.h> #define MAXSIZE 4 typedef struct {
int r[MAXSIZE];
int length; //用于记录顺序表的长度
}SqList; void swap(SqList *L,int i,int j)
{
int temp = L->r[i];
L->r[i] = L->r[j];
L->r[j] = temp;
} //首先初始化结构体的r数组
void main()
{
SqList n;
n.length = MAXSIZE; //srand((unsigned) time(NULL)); //用时间做种,每次产生随机数不一样 int i = ;
/*
for (; i<MAXSIZE ; i++) {
n.r[i] = rand() % 101;//产生0-100的随机数
}
*/
n.r[] = ;
n.r[] = ;
n.r[] = ;
n.r[] = ; //依次输出
for (i=;i<MAXSIZE;i++) {
printf("%d\n",n.r[i]);
}
}

  1.定义一个非标准冒泡排序算法的方法

 void BubbleSort0(SqList *L)
{
// 4,3,2,1
//推导过程
//第一次外层循环
// 4和3比较 3,4,2,1
// 3和2比较, 2,4,3,1
// 3和1比较, 1,4,3,2 //第二次外层循环 从第2个元素开始
// 4和3比较 1,3,4,2
// 3和2比较 1,2,4,3 //第三次外层循环,从第3个元素开始
// 4和3比较 1,2,3,4 printf("非标准冒泡排序后结果:\n"); int i,j;
for (i=;i<L->length-;i++){
for (j=i+;j<L->length;j++){
if (L->r[i] > L->r[j])
swap(L,i,j);
}
} }

  上面也说了,此方案并不能称得上'真正'的冒泡排序(具体可以看推到过程),因为不是相邻元素两两比较

 2. 冒泡排序算法 (待优化)

 void BubbleSort(SqList *L)
{
// 4,3,2,1 , 最多循环3次 // 外层第一次循环
// j=0, 4和3比较, 3,4,2,1,
// j=1, 4和2比较, 3,2,4,1
// j=2, 4和1比较, 3,2,1,4 // 外层第二次循环 3,2,1,4
// j=0, 3和2比较, 2,3,1,4,
// j=1, 3和1比较, 2,1,3,4
// j=2, 3和4比较, 2,1,3,4 // 外层第三次循环 2,1,3,4
// j=0, 2和1比较, 1,2,3,4,
// j=1, 2和3比较, 1,2,3,4,
// j=2, 3和4比较, 1,2,3,4, // 由此可推出, 内层只需要 n - 1次循环, 外层只需要循环 n-1次即可
//从第三次外层循环可以看出,其实内循环是没有比较再去比较2和3, 3和4的 printf("冒泡排序后结果:\n");
int i,j;
for (i=;i<L->length;i++){
for (j=;j<L->length-;j++){
if (L->r[j] > L->r[j+])
swap(L,j,j+);
}
}
}

  优化后的版本:

 //冒泡排序,优化版
void BubbleSort1(SqList *L)
{
// 4,3,2,1 , 最多循环3次 // 外层第一次循环
// m = 3
// j=0, 4和3比较, 3,4,2,1,
// j=1, 4和2比较, 3,2,4,1
// j=2, 4和1比较, 3,2,1,4 // 外层第二次循环 3,2,1,4
// m = 2 , 因为最大的已经沉入最底
// j=0, 3和2比较, 2,3,1,4,
// j=1, 3和1比较, 2,1,3,4 // 外层第三次循环 2,1,3,4
// m = 1, 前面循环的2次, 最后2个元素已经排好序, 只需要循环1次,比对前2个即可
// j=0, 2和1比较, 1,2,3,4, printf("冒泡排序(优化算法)结果:\n");
int i,j,m = L->length; //m = 4
for (i=;i<L->length;i++){ m -= ; for (j=;j<m;j++){
if (L->r[j] > L->r[j+])
swap(L,j,j+);
}
}
}

  结合上面 理解冒泡排序的实现过程. 调用BubbleSort1 打印 

    BubbleSort1(&n);

     for (i=;i<MAXSIZE;i++) {
printf("%d\n",n.r[i]);
}

  

c语言冒泡排序的更多相关文章

  1. c语言冒泡排序,指针,数组

    冒泡排序算法的运作如下: 比较相邻的元素.如果第一个比第二个大,就交换他们两个. 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对.在这一点,最后的元素应该会是最大的数. 针对所有的元素重复 ...

  2. 史上最详细的C语言冒泡排序算法

    未经同意,请勿转载. void bubbing(){ ] = {,,,,,,,,,};//define init the array //going to the exinternal loop,st ...

  3. c语言冒泡排序算法

    案例一: #include <stdio.h> int main(void){ int a[5]; printf("please input sort number:" ...

  4. C语言冒泡排序法分析及代码实现

    冒泡排序法: 所谓冒泡排序法,就是对一组数字进行从大到小或者从小到大排序的一种算法.具体方法是,相邻数值两两交换.从第一个数值开始,如果相邻两个数的排列顺序与我们的期望不同,则将两个数的位置进行交换( ...

  5. c语言----- 冒泡排序 for while do-while 递归练习

    1. 冒泡排序简介(默认从小到大排序) 核心思想:只比较相邻的两个元素,如果满足条件就交换    5 8 2 1 6 9 4 3 7 0 目标:0 1 2 3 4 5 6 7 8 9 第一次排序: 5 ...

  6. C语言 · 冒泡排序

    for(int k=0;k<N;k++) {  for(int j=k+1;j<N;j++){    if(a[k]>a[j]){      int t = a[k];      a ...

  7. c 语言冒泡排序

    重要的不是代码 而是思想思路 #include<stdio.h> void Print(int *num, int n) {     int i;     for(i = 0; i < ...

  8. 以冒泡排序为例--malloc/free 重定向stdin stdout

    esort.c 代码如下,可关注下mallloc/free,freopen重定向的用法,排序为每轮将最小的数放在最前面: #include<stdio.h> #include<mal ...

  9. C语言知识汇总,史上最全面总结,没有之一

    C语言基础 C语言学习路线 C语言入门笔记 初识C语言 简单的C程序示例 我们编写的C代码是怎样跑起来的? 简单示例,VS2019调试C语言程序 C语言基础-数据类型 深入理解变量,变量的声明,定义, ...

随机推荐

  1. js正则表达式(常用)

    正则表达式(常用) 写法 js写法 var re = new RegExp("a","i"); perl写法 var re = /a/ ; 量词 {n} 正好出 ...

  2. nvm

    nvm install stable #安装最新稳定版 node,现在是 5.0.0 nvm install 4.2.2 #安装 4.2.2 版本 nvm install 0.12.7 #安装 0.1 ...

  3. linux命令小常识

    作为一个tester我们必须要会linux,也许你会说不用也可以.那么我想问,你部署测试环境在哪里,你下载war包并部署war包呢,你看日志在哪里? 基于测试需要用到liunx,我这里只针对需要用到的 ...

  4. VC编程小技巧之框架窗口及其他

    1.修改主窗口风格 AppWizard生成的应用程序框架的主窗口具有缺省的窗口风格,比如在窗口标题条中自动添加文档名.窗口是叠加型的.可改变窗口大小等.要修改窗口的缺省风格,需要重载CWnd::Pre ...

  5. HTML特殊字符编码对照表

    HTML特殊字符编码对照表 特殊符号 命名实体 十进制编码 特殊符号 命名实体 十进制编码 特殊符号 命名实体 十进制编码 Α Α Α Β Β Β Γ Γ Γ Δ Δ Δ Ε Ε Ε Ζ Ζ Ζ Η ...

  6. VS有效序列号

    VS2005 : KYTYH-TQKW6-VWPBQ-DKC8F-HWC4J VS2008 : PYHYP-WXB3B-B2CCM-V9DX9-VDY8T VS2010 : YCFHQ-9DWCY-D ...

  7. dubbo-admin重新编译后部署出现 valid LOC header (bad signature)异常

    前段时间从网上下载dubbo-admin发现在jdk1.7下不可用,后来根据网上说的升级了jar包版本还是有问题,于是观察了编译发现编译时出现类似如下异常: --------------------- ...

  8. 通过innobackupex实现对MySQL的完整备份与还原

    备份 新建一个用于存放备份的目录 mkdir /backup 执行以下命令: innobackupex --password=test /backup/ 执行完后你会看到“completed OK!” ...

  9. 二分查找-python

    约12年年底的时候,接触了python不到半年的样子,入门是直接实现GUI测试case的.今天面试地平线机器人,发现忘得差不多了- -. 当时的问题是这样的 写一个二分查找是实现,我好像不记得二分查找 ...

  10. 动态加载script文件的两种方法

    第一种就是利用ajax方式,把script文件代码从后台加载到前台,然后对加载到的内容通过eval()执行代码.第二种是,动态创建一个script标签,设置其src属性,通过把script标签插入到页 ...