七大排序模板

地址:https://mp.weixin.qq.com/s?__biz=MzI5MzIwNDI1MQ==&mid=2650123982&idx=2&sn=88f54e1e88b903cbf67399e0fd612ec8&chksm=f474b6bac3033fac33ada3ebcb6cb5f3e5705806188ba0350fc255b5a12a5fe527d2c2d8f515&mpshare=1&scene=23&srcid=0811CHPHjBSBJkDJemjkpIgg#rd

目录:冒泡,选择,插入,希尔,归并,快排  以及  堆排

一、冒泡

1.经典排序

	for(i=0;i<n-1;i++)
	{
		int flag=1;
		for(j=0;j<n-i-1;j++)
			if(a[j]>a[j+1])
			{
				int t=a[j+1];
				a[j+1]=a[j];
				a[j]=t;
				flag=0;
			}
		if(flag)
			break;
	}

2.简化版

 for(i=0;i<n;i++)
	for(j=i+1;j<n;j++)
		if(a[i]>a[j])
		{
			int t=a[i];
			a[i]=a[j];
			a[j]=t;
		}

二、选择排序

for(i=0;i<n;i++)
{
	int min=i;
	for(j=i+1;j<n;j++)
		if(a[min]>a[j])
			min=j;
	if(min!=i)
	{
		int t;
		t=a[i];
		a[i]=a[min];
		a[min]=t;
	}
}

三、插入排序

for(i=0;i<n;i++)
{
	int temp = a[i];//必须有,这就是防覆盖的关键
	for(j=i;j>0;j--)
	{
		if(temp < a[j-1])
			a[j] = a[j-1]; //将所有在nums[i]之前的大于nums[i]的值都往后移一位
		else
			break; 
	}
	a[j] = temp;
}

四、希尔排序

for(incre=n/2;incre>0;incre/=2)//步长
{
	for(i=incre;i<n;i++)//列的开始
	{
		int t=a[i];
		for(j=i;j>=incre;j-=incre)//那一列中的元素
		{
			if(t<a[j-incre])
				a[j]=a[j-incre];
			else
				break;
		}
		a[j]=t;
	}
}

五、归并排序 MergeSort

void sort(int a[],int low,int high)//将数组分为2部分
{
	if(low<high)
	{
	   int mid=(low+high)/2;
	   sort(a,low,mid);
	   sort(a,mid+1,high);
	   merge(a,low,mid,high);
	}
}
void merge(int a[],int low,int mid,int high)//将上面分成的二部分进行排序(合并)
{
	int i=low,j=mid+1;
	int b[n],k=0;
	while(i<=mid&&j<=high)
	{
		if(a[i]>a[j])
			b[k++]=a[j++];
		else
			b[k++]=a[i++];
	}
	while(j<=high)
		b[k++]=a[j++];
	while(i<=mid)
		b[k++]=a[i++];
	for(i=0;i<=high-low;i++)
		a[i+low]=b[i];
}

六、快速排序 QuickSort

缺陷:给出二元数组a[MAXN][2],按第一个关键值从小到大排序后输出,要求第一关键值相同情况下不改变原数组次序

例如:二元 (1,0),(1,2)排序后改变位置。

void Qsort(int nums[],int left,int right)
{
	if(left>right)
		return ;
	int i=left,j=right,pivot=nums[left];
	while(i<j)
	{
		while(i<j&&nums[j]>=pivot)//保证基准右边的大于他,由于基准为left,所以先看右边的,也就是j
			j--;
		nums[i]=nums[j];
		while(i<j&&nums[i]<=pivot)//保证基准左边的小于他
			i++;
		nums[j]=nums[i];
	}//以基准为界,左小右大
	nums[i]=pivot;
	Qsort(nums,left,i-1);//左边继续
	Qsort(nums,i+1,right);//右边再来
}

七、堆排序 HeapSort

void percDown(int nums[],int i,int size)//最大堆
{
	int left = 2*i+1;
	int right = 2*i+2;
	int max = i;
	if(left < size && nums[left] > nums[max])
		max = left;
	if(right < size && nums[right] > nums[max])
		max = right;
	if(max != i)
	{
		int temp = nums[i];
		nums[i] = nums[max];
	    nums[max] = temp;
		percDown(nums,max,size);
	}			
}
void HeapSort(int nums[],int len)
{
   int i;
   for(i=len/2;i>=0;i--)//构建最大堆,从叶子向root开始建立,所以只考虑孩子(我们建立的就是parent且下级为最大堆)
		percDown(nums,0,len);
   for( i=len-1;i>=1;i--)//循环,每次把根节点和最后一个节点调换位置
   {
		int temp = nums[0];
		nums[0] = nums[i];
		nums[i] = temp;
		percDown(nums,0,i);//0,即全部调整,i树的范围,每次将最大放到最后,size缩小
	}
}

 

 

 

 

 

 

 

 

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 蓝桥杯Python大学B组的高频考点有以下几个: 1. 数据类型:包括整数、浮点数、字符串、列表、字典等。重点掌握它们的基本操作方法,如索引、切片、增删改查等。 2. 条件语句与循环结构:if语句和for循环是编程中常用的控制流程语句,灵活运用它们可以实现不同的功能。 3. 函数:函数是将一段可重复使用的代码块封装起来,以供其他部分调用。理解函数的定义、调用、参数传递等基本概念,并能熟练运用。 4. 文件操作:读取和写入文件是程序与外部环境数据交互的重要方,要能够使用open()函数打开文件、读取文件内容,以及写入文件等操作。 5. 异常处理:处理程序运行时可能出现的异常情况,如文件不存在、除零错误等。了解常见的异常类型,并能使用try-except语句进行异常处理。 6. 面向对象编程:理解类与对象的概念,了解如何定义类及其属性和方法,以及如何创建和使用对象。 7. 模块与库的使用:Python拥有丰富的第三方库和模块,能够快速地解决一些常见问题。掌握如何导入、调用和使用这些库和模块,能够提高编程效率。 以上这些是蓝桥杯Python大学B组的高频考点模板,希望能对你备考有所帮助。 ### 回答2: 蓝桥杯Python大学B组高频考点模板主要包括基础语法、数据类型、运算符、流程控制、函数、模块、文件操作、异常处理等。 首先,基础语法是我们使用Python语言的基础,包括变量的定义、常量、注释、输入输出等。在考试中,可能会涉及到变量的命名、关键字的使用、注释的添加等方面。 其次,数据类型是Python中非常重要的概念,包括整数、浮点数、字符串、列表、元组、字典等。在考试中,我们需要熟练掌握各种数据类型的定义、常用操作和方法。 第三,运算符是Python中用于数学运算和逻辑运算的符号,包括算术运算符、比较运算符、逻辑运算符等。我们需要理解运算符的优先级、使用方法以及对应的运算规则。 第四,流程控制是Python中实现程序逻辑分支和循环执行的重要方法,包括条件语句和循环语句。我们需要掌握if语句、for循环、while循环等的基本语法和用法。 第五,函数是Python中封装代码的方,可以重复使用,提高代码的复用性。在考试中,我们需要了解函数的定义、参数传递、返回值等方面的知识。 第六,模块是用于组织代码的方,将相关的功能代码放在一个文件中。我们需要了解如何导入模块、调用模块中的函数等。 第七,文件操作是Python中读写文件的操作,包括打开文件、读取文件内容、写入文件等。在考试中,我们需要熟悉文件的打开方、读取方、写入方等。 最后,异常处理是处理程序在运行过程中可能发生的错误的方。我们需要了解如何使用try-except语句捕获和处理异常,以及常见的异常类型。 通过熟练掌握以上高频考点模板,我们可以提高在蓝桥杯Python大学B组考试中的答题效率和准确性。但需要注意的是,除了掌握模板,实际的编程能力和解决问题的能力同样重要。 ### 回答3: 蓝桥杯Python大学B组高频考点模板主要有以下几个方面: 1. 基础语法:Python的基本语法包括变量、数据类型、运算符、控制流等。考生需要熟悉Python的语法规则,包括正确使用变量、常量,运用不同的数据类型进行计算等。 2. 函数与模块:Python内置了许多常用函数和模块,如输入输出函数、数学函数、字符串处理函数等。考生需要了解这些函数的使用方法,能够正确调用函数和模块,解决实际问题。 3. 文件操作:Python提供了操作文件的函数和方法,包括文件的打开、读取、写入、关闭等。考生需要熟悉文件操作的流程和常用函数,能够完成文件的读写和处理。 4. 数据结构与算法:考生需要掌握Python中常用的数据结构和算法,如列表、字典、集合、排序算法、查找算法等。能够灵活运用这些数据结构和算法解决问题,并考虑算法的时间复杂度和空间复杂度。 5. 异常处理:Python中提供了异常处理机制,能够捕获和处理程序运行过程中出现的异常。考生需要了解常见的异常类型和异常处理语句,合理处理程序中可能出现的异常情况,确保程序的健壮性和稳定性。 6. 面向对象编程:Python是一门面向对象的编程语言,考生需要掌握类的定义、实例化、继承、多态等基本概念和操作。能够基于面向对象的思想设计和实现程序,提高代码的复用性和可维护性。 希望以上内容能够对您有所帮助。如果还有其他问题,请继续提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值