当前位置: 首页 > article >正文

c语言-冒泡排序

冒泡排序原理:
冒泡排序是一种简单直观的排序算法,它重复地遍历待排序的元素序列,比较相邻的两个元素,如果它们的顺序不符合要求(例如升序要求前面的元素小于后面的元素),则交换它们的位置。遍历整个序列的过程会多次进行,每一轮都会把一个最大(或最小,取决于排序顺序)的元素“浮”到最右侧。

具体过程如下:

  1. 比较相邻元素: 从第一个元素开始,比较相邻的两个元素的大小。

  2. 交换元素位置: 如果顺序不符合要求(例如升序时前面的元素大于后面的元素),则交换它们的位置。

  3. 一轮结束: 一轮比较和交换之后,最大的元素已经被“浮”到最右侧。

  4. 重复步骤1-3: 重复执行上述步骤,每次都会确定一个未排序部分的最大元素的位置。

  5. 终止条件: 当整个序列都有序时,排序完成。

冒泡排序的特点:

  • 稳定性: 冒泡排序是稳定的排序算法相等元素的相对位置在排序前后不会改变。

  • 时间复杂度: 最坏情况下的时间复杂度为 O(n^2)最好情况下的时间复杂度为 O(n)。

  • 空间复杂度: 冒泡排序仅需要常数级的额外空间。

尽管冒泡排序的性能相对较差,但由于其简单易懂的特点,适用于对数据量较小的序列进行排序。在实际应用中,对于大规模数据集,通常会选择更高效的排序算法,如快速排序或归并排序。

用c语言进行冒泡排序时,遇到的问题:

下面是时隔很久用c写出的代码:(错误的)

#include<stdio.h>
int main(){	
	int arr[]={2,1,5,6,3,4};
	for(int i=0;i<n-1;i++){
		for(int j=0;j<n-1-i;j++){
			if(arr[j]>arr[j+1]){
				arr[j]=arr[j+1];
			}
		}
	}
	print("输出序列:",arr[j]); 
}   

代码存在以下几点错误:

  1. 没有定义变量 n,我假设 n 是数组的长度,因此在代码中添加了 int n = sizeof(arr) / sizeof(arr[0]);

  2. 在冒泡排序中,当发现 arr[j] > arr[j+1] 时,应该交换它们的值,而不是将 arr[j] 赋值为 arr[j+1]。因此,我修改了相应的代码。

  3. printf 函数中,应该使用小写的 printf,而不是 print

修改后的代码如下:

#include<stdio.h>

int main() {
    int arr[] = {2, 1, 5, 6, 3, 4};
    int n = sizeof(arr) / sizeof(arr[0]);

    for (int i = 0; i < n - 1; i++) {
        for (int j = 0; j < n - 1-i; j++) {
            if (arr[j] > arr[j+1]) {
                // 交换 arr[j] 和 arr[j+1] 的值
                int temp = arr[j];
                arr[j] = arr[j+1];
                arr[j+1] = temp;
            }
        }
    }

    printf("输出序列:");
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }

    return 0;
}

在标准的冒泡排序算法中内层循环的终止条件通常是 n - 1 - i其中 i 是外层循环的当前迭代次数。这是因为在每一轮外层循环之后,数组的最后 i 个元素已经被确定为最大的 i 个元素,所以内层循环无需再遍历这些已经确定位置的元素。

这样的代码应该能够正确地对数组进行冒泡排序,并输出排序后的序列。


http://www.kler.cn/a/146520.html

相关文章:

  • JAVA实现五子棋小游戏(附源码)
  • C语言结构体漫谈:从平凡中见不平凡
  • Unity ShaderGraph中Lit转换成URP的LitShader
  • 迅翼SwiftWing | ROS 固定翼开源仿真平台正式发布!
  • C语言:-三子棋游戏代码:分支-循环-数组-函数集合
  • Qt中容器 QVector、QList、QSet和QMap 性能与用途比较
  • C#文件基本操作(判断文件是否存在、创建文件、复制或移动文件、删除文件以及获取文件基本信息)
  • 四、IDEA创建项目时,Maven Archetype模板工程说明
  • P18 C++ 继承
  • Rust语言入门教程(四) - 数据类型
  • 案例034:基于微信小程序的课堂助手系统
  • app自动化测试接口文档与在线测试
  • LangChain 9 模型Model I/O 聊天提示词ChatPromptTemplate, 少量样本提示词FewShotPrompt
  • 基于C#实现奇偶排序
  • sql 动态语句
  • vue+springboot读取git的markdown文件并展示
  • Camtasia Studio2024专业的屏幕录制和视频剪辑软件
  • 人工智能 -- 神经网络
  • 切水果小游戏
  • 【开源】基于JAVA的海南旅游景点推荐系统
  • Python 测试框架 Pytest 的入门
  • <JavaEE> Java中线程有多少种状态(State)?状态之间的关系有什么关系?
  • Java中使用 com.google.zxing 生成二维码
  • 软件测试基础知识
  • c语言练习12周(11~15)
  • 【Vulnhub靶机】Jarbas--Jenkins