排序 算法

稳定排序与不稳定排序
如果我们对一串数字排序,那么稳定与否并不是很重要,因为一串数字的属性是单一的,就是数值的大小。但是排序的元素的属性往往不是只有一个属性,例如我们对一群人进行年龄排序,但是人除了年龄属性还有身高体重属性,在年龄相同时如果不想破坏原先身高体重的次序,就必须用稳定排序算法。

判断某个排序算法是否稳定,可以简单的理解为:排序前后两个相等的数在其在序列的前后位置和排序后它们两个的前后位置顺序是否相同。
如果相同,则是稳定排序算法。
如果不同,则是不稳定排序算法。

稳定排序:冒泡排序,插入排序,归并排序
不稳定排序:选择排序,希尔排序,快速排序

1.冒泡排序算法实现

原理: 排序的次数是排序数组长度减一,排序依次将待排序数组的最大值排到数组的末尾。每一次的排序,需要比较的次数也会递减。时间复杂度O(N^2)

比如

int array [] =[2,5,1,3,4];

第一次排序结果为:

int array [] =[2,1,3,4,5];

算法实现如下:

void maopaosort(vector<int> arraynum)///冒泡排序
{
   
	for (int i=0;i<arraynum.size()-1;i++)///排序的次数 
	{
   
		int isChange=0;
		for (int j=0;j<arraynum.size()-i-1;j++)每一次排序要比较的次数
		{
   
			if (arraynum[j]>arraynum[j+1])
			{
   
				int tem = arraynum[j] ;
				arraynum[j]=arraynum[j+1] ;
				arraynum[j+1]=tem;	
				isChange=1;
			}
		}
		if (isChange == 0)
		{
   
           break;
		}
	}
}

代码中的 isChange 是对冒泡排序的一点小优化 。

2.选择排序

工作原理:每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在数组的起始(末尾)位置,直到待排序的数组全部排序完。时间复杂度O(N^2)

比如:

int[] arrays = {
   2, 3, 1, 4, 3, 5, 1, 6, 1, 2, 3, 7, 2, 3};

第一次排序后:(将最大值的位置 “7”与数组的最后一个值的位置“3”对换)

int[] arrays = {
   2, 3, 1, 4, 3, 5, 1, 6, 1, 2, 3, 3, 2, 7};

算法实现如下:

void Select_Sort(vector<int> arraynum)///
{
   
	int pos; //记录当前趟数的最大值角标
	int tem; // 交换的变量
	for (int i=0;i<arraynum.size()-1;i++) 
	{
   
		pos=0;
		for 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java排序算法是用于对一系列数据进行排列顺序的一种算法。在Java中,常见的排序算法包括冒泡排序、选择排序、插入排序、快速排序、归并排序等。 冒泡排序是一种比较简单的排序算法,它通过对相邻的元素进行比较和交换来实现排序。该算法的时间复杂度为O(n^2),属于比较低效的排序算法。选择排序是一种简单直观的排序算法,它通过选择最小的元素并放置在已排序的部分来实现排序。该算法的时间复杂度也是O(n^2)。 插入排序是一种比较高效的排序算法,它通过将未排序的元素插入到已排序的部分来实现排序。该算法的时间复杂度也是O(n^2)。快速排序是一种递归的排序算法,它通过选取一个基准值来对数组进行分区,并对每个分区进行排序来实现最终的排序。该算法的时间复杂度为O(nlogn),是比较高效的排序算法之一。 归并排序是一种分治的排序算法,它将数组分成两个子数组,并对每个子数组进行排序,最后将两个子数组合并成一个有序数组。该算法的时间复杂度也是O(nlogn)。在实际应用中,我们通常会选择合适的排序算法来应对不同的排序需求,比如对于小规模数据可以选择简单的排序算法,对于大规模数据可以选择高效的排序算法。总之,了解Java排序算法的原理和性能表现对于编程人员来说是非常重要的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值