排序——冒泡排序

冒泡排序的基本思想

从前往后(或从后往前)两两比较相邻元素的值,若为逆序(即 A [ i − 1 ] < A [ i ] A\left [ i-1\right ]<A\left [ i\right ] A[i−1]<A[i]),则交换它们,直到序列比较完。

算法代码

c++ 复制代码
#include <iostream>
using namespace std;

//冒泡排序算法 
void BubbleSort(int nums[],int n){
	int i,j,temp;
	for(i=0;i<n;i++){
		for(j=0;j<n-i-1;j++){		//一趟冒泡 
			if(nums[j]>nums[j+1]){	//逆序 
				temp=nums[j];		//交换 
				nums[j]=nums[j+1];
				nums[j+1]=temp;	
			}	
		}
	}
} 

//打印数组 
void printNum(int numbers[],int n){
	for(int i=0;i<n;i++){
		cout<<numbers[i]<<" ";
	}
}

int main()
{
	int numbers[10]={3,44,38,5,47,15,36,26,27,2};
	int n=sizeof(numbers)/sizeof(numbers[0]);	//数组长度 
	BubbleSort(numbers,n);		//调用 BubbleSort 函数进行插入排序 
	printNum(numbers,n);		//打印数组 
    return 0;
}

算法性能分析

  • 空间复杂度: O ( 1 ) O(1) O(1)

  • 时间复杂度: O ( n 2 ) O(n^2) O(n2)

  • 算法稳定性[1](#1):稳定


  1. 算法的稳定性:若待排序表中有两个元素 R i R_i Ri 和 R j R_j Rj,其对应的关键字相同即 k e y i = k e y j key_i = key_j keyi=keyj,且在排序前 R i R_i Ri 在 R j R_j Rj 的前面,若使用某一排序算法排序后, R i R_i Ri 仍在 R j R_j Rj 的前面,则称这个排序算法是稳定的,否则称排序算法是不稳定 的。 ↩︎
相关推荐
m0_716765237 小时前
数据结构--循环链表、双向链表的插入、删除、查找详解
开发语言·数据结构·c++·学习·链表·青少年编程·visual studio
XY_墨莲伊7 小时前
【编译原理】实验一:基于正则文法的词法分析器设计与实现
开发语言·数据结构·算法
剑挑星河月7 小时前
394.字符串解码
数据结构·算法·leetcode
算法鑫探7 小时前
C语言实现 简易计算器教程
c语言·数据结构·算法·新人首发
得物技术7 小时前
生成式召回在得物的落地技术分享与思考
算法·性能优化·程序员
W23035765738 小时前
回溯法经典实战:0/1 全排列与 N 皇后问题(递归 + 非递归双实现)
算法·回溯法·n皇后
YuanDaima20488 小时前
队列与单调队列基础原理与题目说明
人工智能·python·算法·leetcode·队列·手撕代码
董董灿是个攻城狮8 小时前
放风的 Claude 你怕不怕
算法
wunaiqiezixin8 小时前
链表多项式大整数-BigInt
数据结构·c++·链表
阿杰学AI8 小时前
AI核心知识122—大语言模型之 直接偏好优化(简洁且通俗易懂版)
人工智能·算法·机器学习·ai·强化学习·dpo·直接优化偏好