排序算法之冒泡排序

对于大多数学计算机的人来说,冒泡排序应该都是接触的第一种排序方式,冒泡排序的排序思想是比较简单的,

它的算法的是:
  1. 比较相邻的元素。如果第一个比第二个大,就交换他们两个。
  2. 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。
  3. 针对所有的元素重复以上的步骤,除了最后一个。
  4. 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。

     

    冒泡排序的实现如下:

     1 #include<stdio.h>
     2 int main()
     3 {
     4     int array[] = {3, 5, 2, 6, 4, 1};
     5     int count = sizeof(array) / sizeof(array[0]);
     6     int i, j;
     7     for(i = 0; i < count - 1; i++) {
     8         for(j = 0; j < count - 1 - i; j++) {
     9             if (array[j] > array[j + 1]) {
    10                 int temp = 0;
    11                 temp = array[j];
    12                 array[j] = array[j + 1];
    13                 array[j + 1] = temp;
    14             }
    15         }
    16     }
    17     for(i = 0; i < count; i++) {
    18         printf("%d\n", array[i]);
    19     }
    20 
    21 
    22 
    23 
    24 
    25     return 0;
    26 }

     

    其实冒泡排序还可以优化,就是当比较和交换过程中数组已经有序的情况,这样的话就不用再进行冒泡了,所以冒泡排序可以这样优化:

     1 #include<stdio.h>
     2 int main()
     3 {
     4     int array[] = {3, 5, 2, 6, 4, 1};
     5     int count = sizeof(array) / sizeof(array[0]);
     6     int i, j;
     7     int flag = 1;
     8     for(i = 0; i < count - 1 && 1 == flag; i++) {
     9         flag = 0;
    10         for(j = 0; j < count - 1 - i; j++) {
    11             if (array[j] > array[j + 1]) {
    12                 int temp = 0;
    13                 temp = array[j];
    14                 array[j] = array[j + 1];
    15                 array[j + 1] = temp;
    16                 flag = 1;
    17             }
    18         }
    19     }
    20     for(i = 0; i < count; i++) {
    21         printf("%d\n", array[i]);
    22     }
    23 
    24     return 0;
    25 }

     

代码下载链接: https://pan.quark.cn/s/6b27a128162e 【关于IAR for Arm 9.20.1的安装指导】 IAR Systems作为业内知名的嵌入式系统开发工具供应商,其推出的IAR Embedded Workbench是一款面向多种微控制器(MCU)的集成开发环境(IDE)。本指导将系统性地阐述安装IAR for ARM 9.20.1版本的具体流程,该版本是专门为基于ARM架构的嵌入式设备量身打造的开发工具。 1. **前期准备** 在启动安装流程之前,务必核实计算机的环境配置符合以下系统要求: - 操作系统版本:Windows 7或更新版本 - 硬盘容量:确保至少有1GB的可用存储空间 - 系统兼容性:支持在32位及64位Windows操作系统上运行 2. **获取与解压缩** 需要从官方网站或者指定的链接获取"IAR For Arm 9.20.1"的压缩文件。文件下载完毕后,借助解压缩软件(例如7-Zip)将内容解压到用户指定的文件夹中。 3. **启动安装流程** 进入解压后的文件夹,找到并执行"IAREmbeddedWorkbenchInstaller.exe"文件,从而启动IAR的安装向导程序。 4. **安装向导界面** - **初始界面**:仔细阅读并同意许可协议条款,随后点击“Next”进入下一阶段。 - **组件选择**:IAR Embedded Workbench通常集成了多个功能模块,包括编译器、调试器接口等。系统默认选中所有模块,用户也可依据实际需求进行个性化选择。本例中采用默认设置,并继续点击“Next”。 - **设定安装位置**:用户可以选择采用系统推荐的安装路径,或者自定义安装位置。确认选择...
内容概要:本文围绕基于反步终端滑模控制的永磁同步电机(PMSM)位置控制器三环伺服系统展开深入研究,旨在通过Matlab/Simulink平台构建完整的控制系统仿真模型,实现对PMSM高精度位置控制的设计与验证。研究系统性地阐述了反步终端滑模控制(Backstepping Terminal Sliding Mode Control, BTSMC)的理论基础,重点剖析其在应对系统强非线性、外部未知扰动及参数摄动等挑战时所展现出的卓越鲁棒性与动态性能优势。通过构建包含电流环、速度环和位置环的三闭环级联控制架构,实现了对电机多物理量的精细化协同控制,显著提升了系统的响应速度、稳态精度和抗干扰能力。文章不仅提供了详尽的控制律推导过程,还给出了完整的Simulink模块化实现方案,涵盖了坐标变换、控制器设计、空间矢量脉宽调制(SVPWM)等关键环节,为相关领域的科研与工程实践提供了可复现、可拓展的技术范例。; 适合人群:具备自动控制理论、电机学基础知识及Matlab/Simulink仿真操作经验的研究生、高校教师、科研院所研究人员以及从事高性能电机驱动、伺服系统开发的工程技术专业人员。; 使用场景及目标:①服务于高等院校和科研机构中关于现代非线性控制理论的教学案例与课题研究;②为工业自动化领域中高精度数控机床、机器人关节、精密仪器等对伺服性能有严苛要求的应用场景提供先进的控制策略参考与技术实现路径;③支撑高水平学术论文的复现、不同先进控制算法(如传统PID、普通滑模、自适应控制等)的性能对比分析,并为进一步提出创新性复合控制方法奠定研究基础; 阅读建议:建议读者在学习过程中紧密结合文中的数学推导与Simulink仿真模型,逐模块理解控制策略的实现逻辑,特别关注滑模面的设计、李雅普诺夫函数的构造、控制器增益参数的整定方法以及三环之间的动态耦合关系。应充分利用所提供的仿真资源进行反复调试与参数优化,通过观察不同工况下的系统响应曲线,深入探究控制算法的内在机理,从而有效提升对复杂非线性系统建模、分析与设计的综合能力。
内容概要:本文档由“荔枝科研社”团队整理,系统性地提供了多个科研方向的MATLAB与Python仿真技术支持与资源下载服务,核心聚焦于虚拟电厂运行优化、日前-实时电力交易、激励型需求响应定价机制等电力系统前沿课题。通过构建包含模型预测控制(MPC)、交替方向乘子法(ADMM)、智能优化算法(如PSO、GA、鲸鱼算法等)在内的数学模型与仿真框架,深入探讨了计及多重市场机制与需求响应的虚拟电厂优化调度策略,旨在提升能源系统的经济性、可靠性和低碳水平。文档还涵盖了微电网协调调度、综合能源系统优化、风光储氢协同、电热气耦合、碳交易机制等热点研究方向,并配套提供完整的代码、数据、论文复现模型及Simulink仿真案例,形成从理论建模到算法实现的全流程科研支持体系。; 适合人群:面向具备电力系统、自动化、能源工程、控制科学或相关专业背景的研究生、高校科研人员及从事新能源、智能电网、综合能源系统、优化算法研发的工程技术人员。; 使用场景及目标:① 复现高水平期刊(如IEEE、EI)论文中的复杂优化模型与先进算法;② 获取虚拟电厂、微电网、综合能源系统等方向的完整项目资源,支撑学位论文、科研课题申报或学术成果转化;③ 借助提供的开源代码与仿真模型快速搭建实验平台,开展创新性研究与算法对比分析。; 阅读建议:建议读者结合自身研究方向,优先选择标注“复现”“顶刊”“EI/IEEE”“Cplex求解”等高价值项目进行深入学习,通过公众号“荔枝科研社”获取网盘资源,并积极参与技术交流以获得持续支持与答疑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值