起泡算法
来源:互联网 发布:java 反射获取注解 编辑:程序博客网 时间:2024/04/26 16:41
冒泡排序算法的运作如下:(从后往前)
- 比较相邻的元素。如果第一个比第二个大,就交换他们两个。
- 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。
- 针对所有的元素重复以上的步骤,除了最后一个。
- 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。[1]
算法稳定性
冒泡排序就是把小的元素往前调或者把大的元素往后调。比较是相邻的两个元素比较,交换也发生在这两个元素之间。所以,如果两个元素相等,我想你是不会再无聊地把他们俩交换一下的;如果两个相等的元素没有相邻,那么即使通过前面的两两交换把两个相邻起来,这时候也不会交换,所以相同元素的前后顺序并没有改变,所以冒泡排序是一种稳定排序算法。
void
bubble_sort(
int
a[],
int
n);
void
bubble_sort(
int
a[],
int
n)
{
int
i, j, temp;
for
(j = 0; j < n - 1; j++)
for
(i = 0; i < n - 1 - j; i++)
{
if
(a[i] > a[i + 1])
{
temp = a[i];
a[i] = a[i + 1];
a[i + 1] = temp;
}
}
}
int
main()
{
int
number[SIZE] = {95, 45, 15, 78, 84, 51, 24, 12};
int
i;
bubble_sort(number, SIZE);
for
(i = 0; i < SIZE; i++)
{
printf
(
"%d"
, number[i]);
}
printf
(
"\n"
);
}
JAVA
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
public class BubbleSort
{
public void sort(int[] a)
{
int temp = 0;
for (int i = a.length - 1; i > 0; --i)
{
for (int j = 0; j < i; ++j)
{
if (a[j + 1] < a[j])
{
temp = a[j];
a[j] = a[j + 1];
a[j + 1] = temp;
}
}
}
}
}
0 0
- 起泡算法
- 双向起泡算法
- 数据结构与算法---起泡排序
- 一天一练之起泡排序算法
- 改进的起泡排序算法--java
- 冒泡排序改进算法(双向起泡)
- 起泡算法的最佳复杂度O(N)
- 八大排序算法(五) 起泡排序
- 数据结构排序算法_起泡排序算法学习
- 输出起泡排序算法每趟的结果
- 排序算法总结---交换排序之起泡排序
- 排序算法(二)--交换排序之起泡排序,快速排序
- PHP学习笔记——冒泡(起泡)排序算法
- 起泡排序
- 起泡排序
- 起泡法
- 事件起泡
- 起泡排序
- hdu 5883 The Best Path 欧拉路 异或
- 将Hive表数据导入到mysql
- 用select模式实现TCP和UDP的混合监听
- [LeetCode-Java]8. String to Integer (atoi)
- nw-HTTP实现
- 起泡算法
- nosql缓存技术之memcached介绍、安装以及使用总结
- 有限状态自动机
- cache
- 分布式一致性原理学习笔记(1)
- 架构专题
- PM狗到底是TMD啥玩意 又DO那些事情
- MapReduce工作原理学习
- 关于pwm波