C程序数组算法 — 冒泡法排序【前冒 || 后冒】
第一种写法(前冒泡):
/* C程序数组算法 — 冒泡法排序
* 此例子按照 大 -> 小 排序
* 原理:两两相比较,然后进行大小对调
* 比较次数: n^2 次
* 说明:冒泡排序是相对稳定的排序算法,当待排序的列有序时,效果最好!
* 时间:2020年7月12日 21:59:22
*/
#include<stdio.h>
int main()
{
int a[10] = {1,3,5,7,9,2,4,6,8,10};
int i,j,temp; // i和j表示下标的 temp 交换时存放临时的值
for(i = 0;i<9;i++) //外层循环 比较n-1次
{
for(j = 0;j<9-i;j++) //内层循环 比较n-1-i次 【i指的是排好了的】
{
if(a[j] < a[j+1]) //前一个元素和后一个元素对比
{
temp = a[j]; //开始交换前后元素
a[j] = a[j+1];
a[j+1] = temp; //交换结束
}
}
} for(i = 0;i<10;i++)//交换好了--- 打印
{
printf("%d\n",a[i]);
} return 0;
}
第二种写法(后冒泡):
/* C程序数组算法 — 冒泡法排序
* 此例子按照 大 -> 小 排序
* 原理:两两相比较,然后进行大小对调
* 比较次数: n^2 次
* 说明:冒泡排序是相对稳定的排序算法,当待排序的列有序时,效果最好!
* 时间:2020年7月12日 21:59:22
*/
#include<stdio.h>
int main()
{
int a[10] = {1,3,5,7,9,2,4,6,8,10};
int i,j,temp; // i和j表示下标的 temp 交换时存放临时的值
for(i = 0;i<9;i++) //外层循环 比较n-1次
{
for(j = 9;j>i;j--) //内层循环 说白了就是要比较n-i-1次,这里的j = n-1(9),j<i ,此时的i是会递减1 的 就相等"n-i-1"中的 "-i",那么"n-i-1"中的 "-1" 就是j了。
{
if(a[j] > a[j-1]) //后一个元素和前一个元素对比
{
temp = a[j-1]; //开始交换前后元素
a[j-1] = a[j];
a[j] = temp; //交换结束
}
}
} for(i = 0;i<10;i++)//交换好了--- 打印
{
printf("%d\n",a[i]);
} return 0;
}
总结前冒和后冒的公式:
前冒:for(i = 0;i < n-1;i++)
{
for(j = 0;j<n-1-i;j++)
{
...交换语句...
}
}
后冒:for(i = 0;i < n-1;i++)
{
for(j = n - 1;j > i;j--)
{
...交换语句...
}
}
希望能帮到大家......../(ㄒoㄒ)/
C程序数组算法 — 冒泡法排序【前冒 || 后冒】的更多相关文章
- Java温故而知新-冒泡法排序
冒泡法排序是各种初学者在学习数组与循环结构时都会练习的一种简单排序算法. 冒泡法的精髓在于比较相邻的两个元素,较大的元素会不断的排到队伍后面去,就像水里的泡泡一样不断向上跑. 想像一下倒在一个透明玻璃 ...
- 冒泡法排序_c++实现
看完了郝斌老师的c语言视频,冒泡法排序,就试着写了.我觉得学习算法最重要的不是代码,而是它的原理. 代码: /** 2 * Copyright (c) 1991 - 2016 Arvin Tang. ...
- 【Java基础】选择排序、冒泡法排序、二分法查找
1.选择排序: //改进后的选择排序,减少交换的次数 public static void sortSelect(int arr[]) { //用于存放最小数的下标 int s; for (int i ...
- C语言 · 冒泡法排序
算法提高 冒泡法排序 时间限制:1.0s 内存限制:512.0MB 输入10个数,用“冒泡法”对10个数排序(由小到大)这10个数字在100以内. 样例输入 1 3 6 8 2 7 ...
- 8. 冒泡法排序和快速排序(基于openCV)
一.前言 主要讲述冒泡法排序和快速排序的基本流程,并给出代码实现,亲测可用. 二.冒泡法排序 冒泡法排序主要是将相邻两个值比较,把小的向前冒泡,大的向后沉淀,时间复杂度为O(n2).主要思想如下: 分 ...
- Python 冒泡法排序
def sequence(disorder='', separators=''): arrays = disorder.split(separators) def desc(): for i in r ...
- C#冒泡法排序源码
如下内容内容是关于C#冒泡法排序的内容,应该对码农有一些用途. int[] myArray = new int[] { 10, 8, 3, 5, 6, 7, 4, 6, 9 }; for( int j ...
- [python,2018-01-15] 冒泡法排序
想写一个冒泡法排序,没什么思路,就先写了个java的 public static void main(String[] args) { int array[] = {88,2,43,12,34,8,6 ...
- c#冒泡法排序
1.通过冒泡法实现一个int数组的有小到大的排序 代码如下: //用for语句来实现排序功能,冒泡排序 static void Sort(int[] number) { ; i < number ...
随机推荐
- vue2.0用法以及环境配置
一.配置环境搭建 1.安装node.js (可以去官网看) 2.安装git (推荐看廖雪峰文章,点击查看) 3.安装vue: cmd:npm install vue //最新稳定版本 npm inst ...
- Techme INC:红光和近红外光疗法有效加速肌肉恢复,美国橄榄球队已采用
Techme INC创始人兼董事长MADELEINE VAUGHAN表示:在运动结束后,肌肉纤维因为细微损伤造成酸痛情形,即是延迟性肌肉酸痛-DOMS.这类酸痛发生时,需要适度的恢复,避免造成肌肉拉伤 ...
- 华盛顿邮报专访:SPC能否再掀起币圈新浪潮?
近日,美国知名媒体华盛顿邮报对话NGK灵石团队技术副总裁Daphne Patel女士,对话主题为"SPC能否再掀起币圈新浪潮".此次对话以问答的形式展开,将SPC的最新情况呈现在你 ...
- 知名金融媒体采访行业大咖,多方推动BGV茁壮成长
近来,多家知名金融媒体如纽约金融时报.伦敦金融时报等采访NGK官方代表洛索斯夫,以及美国当地行业大咖马库斯等人. 受访的NGK官方代币洛索斯夫回答道,近期官方将会推出NGK的书籍<NGK公链底层 ...
- Echarts制作一张全球疫情图
一.获取全球疫情数据 1)获取API 使用用友提供的新冠肺炎实时数据,登录注册之后可以免费使用. 2)点击用户信息 这里的AIPCODE,复制并保存,用于后续的使用. 3)API的使用 用友有提供一个 ...
- 链接服务器sql语句
EXEC sp_addlinkedserver @server='sha',--被访问的服务器别名 @srvproduct='', @provider='SQLOL ...
- Google单元测试框架gtest之官方sample笔记1--简单用例
1.0 通用部分 和常见的测试工具一样,gtest提供了单体测试常见的工具和组件.比如判断各种类型的值相等,大于,小于等,管理多个测试的测试组如testsuit下辖testcase,为了方便处理初始化 ...
- 微信小程序(三)-事件绑定
小程序事件绑定 https://developers.weixin.qq.com/miniprogram/dev/framework/view/two-way-bindings.html 1.数据 / ...
- 前端axios传递一个包含数组的对象到后台,后台可以用String接收,也可以用List集合接收
前端代码: data() { return { listQuery: { date: [], } }}, //查询列表信息getList() { if (this.listQuery.date == ...
- IDEA总结
1. 什么是idea? idea是Java开发软件 2. IDEA下载 https://www.jetbrains.com/idea/download/download-thanks.html?pla ...