十大排序算法简单讲解

十大排序算法简单讲解

十大排序算法最最通俗易懂的动态图外加简单介绍,具体代码请看下一部分的讲解

自己慢慢更新:

如下:

å¨è¿éæå¥å¾çæè¿°

十大排序算法的复杂度

å¨è¿éæå¥å¾çæè¿°

一,冒泡排序

嗯,先说一下我对这算法的简单理解吧,冒泡排序很形象;在这组数组中将前后两个数进行比较,然后看需要的是升序还是降序,个性化的选择把那个放在前面;然后在遍历n边,后就排序好了

优点,比较好想,缺点,时间复杂度太大,见上表

 

 

å¨è¿éæå¥å¾çæè¿°

#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
using namespace std;
void swap(int &a,int &b)//交换函数 
{
	int tem =a;
	a = b;
	b = tem;
 } 
 void maopao(int a[13123])//冒泡排序 
 {
	for(int i = 0;i < 10;i++)
		for(int j = 0;j < 9-i;j++)
		{
			if(a[j]>a[j+1])
			{
				swap(a[j],a[j+1]);
			}	
		
		} 	
 }
 int main()
 {
 	int a[11] = { 520, 0, 1, 9, 56, 100, 85, 5, 3, 6};
 	maopao(a);
 	for(int i=0;i<10;i++)
 	{
 		cout<<a[i]<<"  ";
	 }
 }

 

二,选择排序

就是三步。

1 将数组划分为有序区和无序区。(开始有序区为空,无序区[0,n-1]) 
2 在无序区中找出最大的那个元素,与该区间第一个元素交换。(有序区元素个数加1,无序区减1) 
3 重复步骤2 ,n-1次,排序完成。(排序趟数为n-1,最后一个元素无需排序)

时间复杂度应该不考,归纳在上图

 

å¨è¿éæå¥å¾çæè¿°

 

代码为:

#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
using namespace std;
void swap(int &a,int &b)//交换函数 
{
	int tem =a;
	a = b;
	b = tem;
 } 
 void xuanzhe(int a[13123])//选这排序 
 {
	for(int i = 0;i < 10-1;i++)
	{
		int min = i;
		for(int j = i;j < 10;j++)//找出无序区的最小元素下标 
		{
			if(a[j ]< a[min])
			{
				min = j;
			}
		} 	
		swap(a[i], a[min]);//无序区第一个元素与最小值交换、 
	}
 }
 int main()
 {
 	int a[11] = { 520, 0, 1, 9, 56, 100, 85, 5, 3, 6};//十个数 
 	xuanzhe(a);
 	for(int i=0;i<10;i++)
 	{
 		cout<<a[i]<<"  ";
	 }
 }

三,插入排序

插入排序跟选择排序很像,都分为有序区和无序区。但是选择排序是每次都从无序区中选出最小元素插入到有序区末尾,而插入排序是直接将数组的第一个元素作为有序区的第一个元素,每次都拿出无序区第个一元素插入到有序区合适的位置上,直到无序区为空,排序完成。

简单就是可分为以下几个步骤:

1 将数组分为有序区和无序区,有序区0,无序区[1,n-1]; 
2 取下无序区第一个元素,保存其值。 
3有序区中元素从后往前与新元素比较,如果新元素更小,旧元素往后移。 
3 重复步骤3,直到新元素大于或等于旧元素,将新元素插入该元素之后。 
4 重复步骤234, n-1次,排序完成。

 

å¨è¿éæå¥å¾çæè¿°

 

代码如下:

 

四,快速排序(这个是最难理解事实上我认为啊)

å¨è¿éæå¥å¾çæè¿°

五,归并排序

å¨è¿éæå¥å¾çæè¿°

六,希尔排序

å¨è¿éæå¥å¾çæè¿°

七,堆排序

å¨è¿éæå¥å¾çæè¿°

八,记数排序

å¨è¿éæå¥å¾çæè¿°

九,桶排序

å¨è¿éæå¥å¾çæè¿°

十,基数排序

å¨è¿éæå¥å¾çæè¿°

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/114860.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 模拟电子技术基础 思维导图

    模拟电子技术基础 思维导图模拟电子技术基础-思维导图参考孙肖子等编著.——北京:高等教育出版社,2012.12稍后将细致介绍每一章节的内容及重点应用!!!

    2022年6月20日
    40
  • Activity 跳转的生命周期变化

    Activity 跳转的生命周期变化####(1)Activity1跳转到Activity2的生命周期流程1.Activity1启动:Activity1:onCreate()Activity1:onStart()Activity1:onResume()2.点击按钮跳转到Activity2:Activity1:onPause()Activity2:…

    2022年5月21日
    48
  • 老王讲二进制 & 0xFF;「建议收藏」

    老王讲二进制 & 0xFF;「建议收藏」$a=2;$b=($a<<6)&0xFF;var_dump($b);die;代码如上 最后结果是128。   $a  二进制左移6位 相当于$a*2^6(2的6次方)。现在告诉你后边的  &0xFF是什么鬼东西。这个东西的有无并不会影响计算结果,但严格意义上说应该有。因为前边的位移运算是二进制算法,计算结果是一个二进制数据,byte类型的

    2022年6月19日
    24
  • matlab插值函数的优缺点,Python和Matlab插值函数的不同结果

    matlab插值函数的优缺点,Python和Matlab插值函数的不同结果我正在将代码从Matlab转换为Python2.7,在转换interp1函数时遇到问题。我看过已经贴出来的类似问题,但还没有解决。问题是新生成的值(yn)的向量的第一个值不同,而其余的几乎相同。当使用不同的插值方法时,我得到的值略有不同,但是同样的问题。目前我真的不知道为什么会这样。有没有人对此有任何了解或看到我可能犯的错误?谢谢。在变量:x=[5.5,5.46678,5….

    2022年5月15日
    31
  • 系统运维架构师体系[通俗易懂]

    系统运维架构师体系[通俗易懂]一、系统运维架构师体系1.系统运维架构体系排列:2.Linux运维架构的薪资水平:3.Linux运维的技能进化论4.Linux运维大致的知识框架4-1.Linux系统初级体系4-2.Linux系统中高级体系5.Linux运维的具体规划实践5-1.Linux运维基础5-2.Linux运维进阶6.Linux工作的必备要求7.Linux运维学习建议一、系统运维架构师体系1.系统运维架构体系排列:Linux运维工程师应用运维工程师,大数据运维工程师,运维开发工程师,云计算运维工程.

    2022年7月17日
    15
  • 关于slam

    关于slam什么是SLAM?机器人在未知环境中,要实现智能化需要完成三个任务,第一个是定位(Localization),第二个是建图(Mapping),第三个则是随后的路径规划(Navigation)。  之前地平线的高翔博士用这样一句话概括SLAM的释义。不过实际生活中的SLAM都是和激光雷达或者单目/双目摄像头结合的形式出现在我们面前的,有时甚至跟更多的传感器融合,这让很多人觉得这个技术不是一两句话能

    2022年10月28日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号