C语言冒泡排序?
将被排序的记录数组R[1..n]垂直排列,每个记录R看作是重量为R.key的气泡。
根据轻气泡不能在重气泡之下的原则,从下往上扫描数组R:凡扫描到违反本原则的轻气泡,就使其向上"飘浮"。
如此反复进行,直到最后任何两个气泡都是轻者在上,重者在下为止。
c语言for语句的冒泡排序法?
冒泡排序是一种基本的排序算法,它的原理是依次比较相邻的元素,如果顺序不对就交换它们。在C语言中,使用for语句实现冒泡排序非常方便。
首先,我们定义一个包含多个元素的数组,用于存放需要排序的数据。接着,利用for语句嵌套实现冒泡排序。外层的循环用来遍历数组,内层的循环用来比较相邻元素的大小。
在内层循环中,如果前一个元素比后一个元素大,就将它们交换位置。这样一轮下来,最大的元素就会被移到数组末尾,接着再次从数组头开始进行下一轮比较,直到所有元素都被排序为止。代码示例:
```
int arr[10] = {3, 5, 1, 2, 4, 6, 7, 9, 8, 0};
int i, j, temp;
for (i = 0; i < 10; i++) {
for (j = 0; j < 9 - i; j++) {
if (arr[j] > arr[j+1]) {
temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
```
在上面的代码中,我们首先定义了一个10个元素的数组,里面包含了需要排序的数据。接着,使用两个for循环,依次比较相邻元素的大小,并交换它们的位置。最终,数组中的元素被按照从小到大的顺序排列。
总之,使用for语句实现冒泡排序是非常方便的,无论是初学者还是有经验的程序员都可以轻松掌握。如果你想进一步深入了解其它排序算法,也可以查阅相关资料,不断学习和探索。
c语言冒泡排序方法默写?
冒泡排序的原理是:从左到右,相邻元素进行比较。每次比较一轮,就会找到序列中最大的一个或最小的一个。这个数就会从序列的最右边冒出来。
以从小到大排序为例,第一轮比较后,所有数中最大的那个数就会浮到最右边;第二轮比较后,所有数中第二大的那个数就会浮到倒数第二个位置……就这样一轮一轮地比较,最后实现从小到大排序。
比如对下面这个序列进行从小到大排序:
第一轮:
1) 90 和 21比,90>21,则它们互换位置:
2) 90 和 132 比,90<132,则不用交换位置。
3)132 和 –58 比,132>–58,则它们互换位置:
4)132 和 34 比,132>34,则它们互换位置:
到此第一轮就比较完了。第一轮的结果是找到了序列中最大的那个数,并浮到了最右边。
比较时,每轮中第 n 次比较是新序列中第 n 个元素和第 n+1 个元素的比较(假如 n 从 1 开始)。
第二轮:
1) 21 和 90 比,21<90,则不用交换位置。
2) 90 和 –58 比,90>–58,则它们互换位置:
3) 90 和 34 比,90>34,则它们互换位置:
到此第二轮就比较完了。第二轮的结果是找到了序列中第二大的那个数,并浮到了最右边第二个位置。
第三轮:
1) 21 和 –58 比,21>–58,则它们互换位置:
2) 21 和 34 比,21<34,则不用交换位置。
到此第三轮就比较完了。第三轮的结果是找到了序列中第三大的那个数,并浮到了最右边第三个位置。
第四轮:1) –58 和 21 比,–58<21,则不用交换位置。至此,整个序列排序完毕。从小到大的序列就是“–58 21 34 90 132”。从这个例子中还可以总结出,如果有 n 个数据,那么只需要比较 n–1 轮。而且除了第一轮之外,每轮都不用全部比较。因为经过前面轮次的比较,已经比较过的轮次已经找到该轮次中最大的数并浮到右边了,所以右边的数不用比较也知道是大的。
还没有评论,来说两句吧...