C++排序算法

本文介绍了四种常见的排序算法:冒泡排序、归并排序、插入排序和基数排序,并提供了相应的代码实现。冒泡排序是一种稳定的排序方式;归并排序通过分治策略实现高效排序;插入排序是通过逐步调整元素顺序完成排序;基数排序则利用数字的位数进行排序。此外,还提及了C++标准库中的sort函数,虽然快速但不稳定。
摘要由CSDN通过智能技术生成

1.冒泡排序

冒牌排序是一种经典的排序算法,它是一种稳定的排序。其原理是如果前面的数比后面的数要大,就交换两个数字的位置。代码如下:

for(int i=1; i<=n-1; i++){
    for(int j=1; j<=n; j++){
        if(a[j]>a[j+1]){
            swap(a[j],a[j+1]);
        }
    }
}

2.归并排序

归并排序的思想是把一串数字从中间分开,然后两边分别排序,最后再合并,从而得到答案。具体代码如下:

void ms(vector<int>& r,int begin,int end){
    if(begin>=end) return;
    int mid=(begin+end)/2;
    ms(r,begin,mid);
    ms(r,mid+1,end);
    vector<int> rtt(end-begin+1);
    int vi=0,i=begin,j=mid+1;
    while(i<=mid && j<=end){
        rtt[vi++]=r[i]>r[j] ? r[i++]:r[j++];
    }
    while(i<=mid) rtt[vi++]=r[i++];
    while(j<=end) rtt[vi++]=r[j++];
    for(int i=0; i<rtt.size(); i++){
        r[begin+i]=rtt[i];
    }
}

3.插入排序

插入排序的思想是,找到一个位置不对的数字,然后一个一个的比较,找到它应该在的位置。代码如下:

	for(int i=1; i<n; i++){
		int key=r[i];
		int j=i-1;
		while(j>=0 && r[j]<key){
			r[j+1]=r[j];
			j--;
		}	
		r[j+1]=key;
	}

4.基数排序

基数排序的原理是定义一个数组,它的下标就是那个相对应的数子的个数。代码如下:

for(int i=0; i<n; i++){
    ans[r[i]]++;
}

5.sort快排

sort快排只要一句代码就能完事。但是sort不稳定,如果两个数字的大小一样的话,它就会交换两个数字的位置。具体代码如下:

sort(a.begin(),a.end());

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值