1. 冒泡排序简介(默认从小到大排序)

 核心思想:只比较相邻的两个元素,如果满足条件就交换

     5 8 2 1 6 9 4 3 7 0

目标:0 1 2 3 4 5 6 7 8 9
  第一次排序:
  5 < 8 不交换

  5 8 2 1 6 9 4 3 7 0

8 >2 满足条件 交换....
  5 2 8 1 6 9 4 3 7 0
  5 2 1 8 6 9 4 3 7 0
  5 2 1 6 8 9 4 3 7 0
  5 2 1 6 8 9 4 3 7 0
  5 2 1 6 8 4 9 3 7 0
  5 2 1 6 8 4 3 9 7 0
  5 2 1 6 8 4 3 7 9 0
  5 2 1 6 8 4 3 7 0 9

  
  
  下一次交换
  2 5 1 6 8 4 3 7 0 9
  2 1 5 6 8 4 3 7 0 9
  2 1 5 6 8 4 3 7 0 9
  2 1 5 6 8 4 3 7 0 9
  2 1 5 6 4 8 3 7 0 9
  2 1 5 6 4 3 8 7 0 9
  2 1 5 6 4 3 7 8 0 9
  2 1 5 6 4 3 7 0 8 9
  

  下一次交换
  1 2 5 6 4 3 7 0 8 9
  1 2 5 6 4 3 7 0 8 9
  1 2 5 6 4 3 7 0 8 9
  1 2 5 4 6 3 7 0 8 9
  1 2 5 4 3 6 7 0 8 9
  1 2 5 4 3 6 7 0 8 9
  1 2 5 4 3 6 0 7 8 9
  

  下一次交换
  1 2 5 4 3 6 0 7 8 9
  1 2 5 4 3 6 0 7 8 9
  1 2 4 5 3 6 0 7 8 9
  1 2 4 3 5 6 0 7 8 9
  1 2 4 3 5 6 0 7 8 9
  1 2 4 3 5 0 6 7 8 9
  

  下一次交换
  1 2 4 3 5 0 6 7 8 9
  1 2 4 3 5 0 6 7 8 9
  1 2 3 4 5 0 6 7 8 9
  1 2 3 4 5 0 6 7 8 9
  1 2 3 4 0 5 6 7 8 9
  

   下一次交换
  1 2 3 4 0 5 6 7 8 9
  1 2 3 4 0 5 6 7 8 9
  1 2 3 4 0 5 6 7 8 9
  1 2 3 0 4 5 6 7 8 9
  

  下一次交换
  1 2 3 0 4 5 6 7 8 9
  1 2 3 0 4 5 6 7 8 9
  1 2 0 3 4 5 6 7 8 9
  

  下一次交换
  1 2 0 3 4 5 6 7 8 9
  1 0 2 3 4 5 6 7 8 9 

  下一次交换
  0 1 2 3 4 5 6 7 8 9

2. 总共进行了 n-1次大的交换(n个元素   只有1个元素不需要排序)

  5 2 1 6 8 4 3 7 0 9   //这次交换 一共变化了9次
  2 1 5 6 4 3 7 0 8 9  // 8次
  1 2 5 4 3 6 0 7 8 9
  1 2 4 3 5 0 6 7 8 9
  1 2 3 4 0 5 6 7 8 9
  1 2 3 0 4 5 6 7 8 9
  1 2 0 3 4 5 6 7 8 9
  1 0 2 3 4 5 6 7 8 9
  0 1 2 3 4 5 6 7 8 9
  每一次小交换是9 8 7 6 5 4 3 2 1 次交换,也就是说

for(int i = ;i < N-;i++){

  for(int j = ;j < N--i;i++){
交换 ...
}
}

3. 实战 for while do-while 递归

#include<stdio.h>
#include<stdlib.h>
#define N 10
void print(int *a){
for (int i = ; i < N; i++)
{
printf("%d ",*(a+i));
}
printf("\n");
}
void maopao_for(int *a){
for (int i = ; i < N - ; i++) {
for (int j = ; j < N - - i; j++) {
if (a[j] > a[j + ]) {
int temp = a[j];
a[j] = a[j + ];
a[j + ] = temp;
}
}
print(a);
}
}
void maopao_while(int *a) {
int i = ;
while (i < N - )
{
int j = ;
while (j < N - - i)
{
if (a[j] > a[j + ]) {
int temp = a[j];
a[j] = a[j + ];
a[j + ] = temp;
}
j++;
}
print(a);
i++;
}
}
void maopao_do_while(int *a) {
int i = ;
do{
int j = ;
do{
if (a[j] > a[j + ]) {
int temp = a[j];
a[j] = a[j + ];
a[j + ] = temp;
}
j++;
} while (j < N - - i);
print(a);
i++;
} while (i < N - );
}
// 递归可以减少一次循环
void maopao_digui(int *a,int count) {
if(count>=N) return ;
for (int j = ; j < N - - count; j++) {
if (a[j] > a[j + ]) {
int temp = a[j];
a[j] = a[j + ];
a[j + ] = temp;
}
}//printf("下一次交换\n\n\n");
print(a);
maopao_digui(a,count+);
}
int main(){
int a[N] = {,,,,,,,,,};
printf("排序前:\n");
print(a);
printf("排序中:\n");
maopao_digui(a,);
printf("排序后:\n");
print(a);
return ;
}

c语言----- 冒泡排序 for while do-while 递归练习的更多相关文章

  1. 用C语言实现汉诺塔自动递归演示程序

    用C语言实现汉诺塔自动递归演示程序 程序实现效果 1.变界面大小依照输入递归数改变. 2.汉诺塔自动移动演示. 3.采用gotoxy实现流畅刷新. 4.保留文字显示递归流程 程序展示及实现 githu ...

  2. c语言的extern与static与递归

    知识点: 外部函数:定义的函数能被本文件和其他文件访问 1> 默认情况下所有函数都是外部函数 2> 不允许有同名的外部函数 内部函数:定义的函数只能被本文件访问,其他文件不能访问 1> ...

  3. 用c语言实现前序创建二叉树(递归),分别用前序,中序,后序遍历,以及分别输出节点个数和叶子节点个数

    本人c语言小白一枚,近期在学习数据结构(c语言版),特写此随笔,做一些总结和分享,如有不当之处,请各位技术大牛斧正 首先我们用一个结构体来抽象树的结点,代码如下(这里我们存放的数据为char型,大家可 ...

  4. c语言冒泡排序

    在C语言中,常用的排序算法有:冒泡排序.快速排序.插入排序.选择排序.希尔排序.堆排序以及归并排序等等. 冒泡排序基本概念:  依次比较相邻的两个数,将小数放在前面,大数放在后面. #include ...

  5. 【C语言入门教程】5.4 递归

    递归函数 是能够直接或通过另一个函数间接调用自身的函数,调用自身的方法称为递归调用.递归调用的本质是使用同一算法将复杂的问题不断化简,直到该问题解决. 例如求斐波那契数列的某一项算法适用于递归函数实现 ...

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

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

  7. 【C语言】reverse_string(char * string)(递归)

    递归reverse_string(char * string)性能. 逆转 原始字符串 更改 相反,打印出的. /* 编写一个函数reverse_string(char * string)(递归实现) ...

  8. sdut oj 1163 C语言实验——排列 (当初不会递归生成排列,这个题目现在才补上 刘汝佳给出了写法 *【模板】 当然有生成全排列的函数存在 )

    C语言实验——排列 Time Limit: 1000ms   Memory limit: 65536K  有疑问?点这里^_^ 题目描述 有4个互不相同的数字,请按序输出由其中三个不重复数字组成的排列 ...

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

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

随机推荐

  1. vue+springboot后台实现页面按钮权限

    思路 1.用户跟角色关联 2.角色跟菜单关联 3.菜单跟菜单下的按钮关联 4.后端返回每个菜单下的按钮,前端通过自定义事件,在每个按钮上加上相应的事件 打字麻烦,还是看图吧! 建立btn.js 然后在 ...

  2. PTA数据结构与算法题目集(中文) 7-26

    PTA数据结构与算法题目集(中文)  7-26 7-26 Windows消息队列 (25 分)   消息队列是Windows系统的基础.对于每个进程,系统维护一个消息队列.如果在进程中有特定事件发生, ...

  3. Redis 练习(二)

    需求: 为购物网站实现登录状态及浏览记录的维护 进入时检查 token 是否已登录 每次进入更新 token 最新进入时间 记录用户浏览的商品信息(最多 25 个) 定时检查 token 数量,如果超 ...

  4. 计算机网络协议,PPP协议分析

    一.基本特点 1.PPP协议是计算机网络体系中第二层(数据链路层)的协议 2.PPP帧格式是以HDLC帧格式为基础,做了很少的改动(区别:PPP是面向字符的,而HDLC是面向位的) 3.PPP协议使用 ...

  5. JAVA debug 断点调试

    更多调试参看 https://www.cnblogs.com/yjd_hycf_space/p/7483471.html 先编译好要调试的程序.1.设置断点 选定要设置断点的代码行,在行号的区域后面单 ...

  6. es搜索排序不正确

    沿用该文章里的数据https://www.cnblogs.com/MRLL/p/12691763.html 查询时发现,一模一样的name,但是相关度不一样 GET /z_test/doc/_sear ...

  7. lr组织架构模式

    基本模式:默认目录由三部分组成 Vuser_int Action,…… Vuser_end 执行时会按照这三个顺序执行(Action部分是可以循环的,也可多个action) 1.lr12录制前可以设置 ...

  8. WEB应用环境的搭建(一)配置Tomcat步骤

    首先了解C/s架构 比如我们常见的QQ,魔兽世界等 这种结构的程序是有服务器来提供服务的,客户端来使用服务 而B/S架构是这样的 它不需要安装客户端,只需要浏览器就可以了 例如QQ农场,这样对客户端的 ...

  9. termux上安装lxml失败

    想试试在手机上随时可以接收到各个平台上最新的消息,于是打算在qpython上写个python的爬虫,安装bs4后,在安装lxml时出现了问题. qpython失败后,改用termux试一下,结果出现了 ...

  10. 2019-05-25 Python之Mongodb的使用

    Mongodb学习总结: one.插入数据pass two.查看数据pass three.修改数据pass four.数据排序pass five.删除数据pass 一.安装Mongodb https: ...