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 < 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 递归练习的更多相关文章
- 用C语言实现汉诺塔自动递归演示程序
		用C语言实现汉诺塔自动递归演示程序 程序实现效果 1.变界面大小依照输入递归数改变. 2.汉诺塔自动移动演示. 3.采用gotoxy实现流畅刷新. 4.保留文字显示递归流程 程序展示及实现 githu ... 
- c语言的extern与static与递归
		知识点: 外部函数:定义的函数能被本文件和其他文件访问 1> 默认情况下所有函数都是外部函数 2> 不允许有同名的外部函数 内部函数:定义的函数只能被本文件访问,其他文件不能访问 1> ... 
- 用c语言实现前序创建二叉树(递归),分别用前序,中序,后序遍历,以及分别输出节点个数和叶子节点个数
		本人c语言小白一枚,近期在学习数据结构(c语言版),特写此随笔,做一些总结和分享,如有不当之处,请各位技术大牛斧正 首先我们用一个结构体来抽象树的结点,代码如下(这里我们存放的数据为char型,大家可 ... 
- c语言冒泡排序
		在C语言中,常用的排序算法有:冒泡排序.快速排序.插入排序.选择排序.希尔排序.堆排序以及归并排序等等. 冒泡排序基本概念: 依次比较相邻的两个数,将小数放在前面,大数放在后面. #include ... 
- 【C语言入门教程】5.4 递归
		递归函数 是能够直接或通过另一个函数间接调用自身的函数,调用自身的方法称为递归调用.递归调用的本质是使用同一算法将复杂的问题不断化简,直到该问题解决. 例如求斐波那契数列的某一项算法适用于递归函数实现 ... 
- c语言冒泡排序,指针,数组
		冒泡排序算法的运作如下: 比较相邻的元素.如果第一个比第二个大,就交换他们两个. 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对.在这一点,最后的元素应该会是最大的数. 针对所有的元素重复 ... 
- 【C语言】reverse_string(char * string)(递归)
		递归reverse_string(char * string)性能. 逆转 原始字符串 更改 相反,打印出的. /* 编写一个函数reverse_string(char * string)(递归实现) ... 
- sdut oj 1163 C语言实验——排列 (当初不会递归生成排列,这个题目现在才补上 刘汝佳给出了写法 *【模板】 当然有生成全排列的函数存在 )
		C语言实验——排列 Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^ 题目描述 有4个互不相同的数字,请按序输出由其中三个不重复数字组成的排列 ... 
- 史上最详细的C语言冒泡排序算法
		未经同意,请勿转载. void bubbing(){ ] = {,,,,,,,,,};//define init the array //going to the exinternal loop,st ... 
随机推荐
- vue+springboot后台实现页面按钮权限
			思路 1.用户跟角色关联 2.角色跟菜单关联 3.菜单跟菜单下的按钮关联 4.后端返回每个菜单下的按钮,前端通过自定义事件,在每个按钮上加上相应的事件 打字麻烦,还是看图吧! 建立btn.js 然后在 ... 
- PTA数据结构与算法题目集(中文)  7-26
			PTA数据结构与算法题目集(中文) 7-26 7-26 Windows消息队列 (25 分) 消息队列是Windows系统的基础.对于每个进程,系统维护一个消息队列.如果在进程中有特定事件发生, ... 
- Redis 练习(二)
			需求: 为购物网站实现登录状态及浏览记录的维护 进入时检查 token 是否已登录 每次进入更新 token 最新进入时间 记录用户浏览的商品信息(最多 25 个) 定时检查 token 数量,如果超 ... 
- 计算机网络协议,PPP协议分析
			一.基本特点 1.PPP协议是计算机网络体系中第二层(数据链路层)的协议 2.PPP帧格式是以HDLC帧格式为基础,做了很少的改动(区别:PPP是面向字符的,而HDLC是面向位的) 3.PPP协议使用 ... 
- JAVA debug 断点调试
			更多调试参看 https://www.cnblogs.com/yjd_hycf_space/p/7483471.html 先编译好要调试的程序.1.设置断点 选定要设置断点的代码行,在行号的区域后面单 ... 
- es搜索排序不正确
			沿用该文章里的数据https://www.cnblogs.com/MRLL/p/12691763.html 查询时发现,一模一样的name,但是相关度不一样 GET /z_test/doc/_sear ... 
- lr组织架构模式
			基本模式:默认目录由三部分组成 Vuser_int Action,…… Vuser_end 执行时会按照这三个顺序执行(Action部分是可以循环的,也可多个action) 1.lr12录制前可以设置 ... 
- WEB应用环境的搭建(一)配置Tomcat步骤
			首先了解C/s架构 比如我们常见的QQ,魔兽世界等 这种结构的程序是有服务器来提供服务的,客户端来使用服务 而B/S架构是这样的 它不需要安装客户端,只需要浏览器就可以了 例如QQ农场,这样对客户端的 ... 
- termux上安装lxml失败
			想试试在手机上随时可以接收到各个平台上最新的消息,于是打算在qpython上写个python的爬虫,安装bs4后,在安装lxml时出现了问题. qpython失败后,改用termux试一下,结果出现了 ... 
- 2019-05-25 Python之Mongodb的使用
			Mongodb学习总结: one.插入数据pass two.查看数据pass three.修改数据pass four.数据排序pass five.删除数据pass 一.安装Mongodb https: ... 
