十大排序|十大排序

 稳定排序:冒泡排序、插入排序、归并排序、基数排序、桶排序

不稳定排序:选择排序、快速排序、希尔排序、堆排序

二、插入排序:

代码:

#include<iostream>
#include<cstdio>
#include<stdlib.h>
#include<vector>
using namespace std;



int main()
{
	int A[6] = { 4,5,6,3,2,1 };
	int n = 6;
	int i, j;
	for (i = 1; i < n; i++)
	{
		if (A[i] < A[i - 1])//i为要检查的元素,要和前面的有序序列(从小到大)
		{
			int temp = A[i];//哨兵位
			for (j = i - 1; j >=0; j--)//和有序队列的每一位元素进行比较,插入合适的位置
			{
				if (A[j] > temp)
				{
					A[j + 1] = A[j];//j移到j+1的位置,都往后挪一位
					break;
				}
			}
			A[j+1] = temp;//最后一个元素是j+1,为什么,因为可能到-1

		}
		
	}

	for (int j = 0; j < n; j++)
	{
		cout <<A[j] << endl;
	}

	return 0;
}

三、希尔排序

在插入排序的基础上

 

 

 

 这里王道讲的代码,有n个数的话实际上留了n+1位,第一位空着做哨兵位。我对数组修改

 

#include<iostream>
#include<cstdio>
#include<stdlib.h>
#include<vector>
using namespace std;

int main()
{

	int A[6] = { 4,5,6,3,2,1 };
	int n = 6;//留第一个位置做哨兵位
	int i, j;
	for (int d = n / 2; d >= 1; d = d / 2)//每一趟d都进行缩小
	{
		for (i = d; i <n;i++)//注意是从d开始
		{
			if (A[i] < A[i - d])//说明可以插入的有序队列,这个if到下面的逻辑基本是插入排序,找到一个合适的位置插入,其余往后移动
			{
				int temp = A[i];
				for (j = i - d; j >=0 && temp< A[j]; j = j - d)
				{
					A[j+d] = A[j];

				}
				A[j + d] = temp;

			}
			
		
			
		}
	}

	for (int j = 0; j < n; j++)
	{
		cout << A[j] << endl;
	}
	return 0;
}

 三、冒泡排序(相邻位置元素进行比较和swap,直到把最大的元素“冒”到最后)


#include<iostream>
#include<cstdio>
#include<stdlib.h>
#include<vector>
using namespace std;
void swap(int *a, int *b)
{
	int temp = *a;
	 *a= *b;
	 *b = temp;

}

void Swap1(int& x, int& y)
{
	int temp = x;
	x = y;
	y = temp;
}

int main()
{
	int A[6] = { 4,5,6,3,2,1 };
	int n = 6;
	for (int i = 0; i < n-1; i++)
	{
		bool flag = false;
		for (int j =0; j < n -1-i; j++)
		{
			if (A[j] > A[j + 1])
			{
				Swap1(A[j], A[j+1]);
				flag = true;

			}
		}
		if (flag == false)//代表一次都没有发生交换,说明数组有序,可以停止比较了
		{
			break;
		}
	}

	for (int j = 0; j < n; j++)
	{
		cout << A[j] << endl;
	}

	return 0;
}

 

快速选择排序------------------基于交换排序,前序遍历构建树,枢轴,

 

 

#include<iostream>
#include<cstdio>
#include<stdlib.h>
#include<vector>
using namespace std;

//类似前序遍历构建树


//1、找到枢轴的位置
int Partition(int A[], int low, int high)
{
	int base = A[low];
	while (low < high)
	{
		while (low <high && A[high] >= base)
		{
			high--;
		}
		A[low] = A[high];
		while (low < high && A[low] <= base)
		{
			low++;
		}
		A[high] = A[low];

	}
	A[low] = base;
	return low;
}


//前序遍历构建树
void QuickSort(int A[], int low, int high)
{
	if (low < high)
	{
		int root_index = Partition(A, low, high);
		QuickSort(A, low, root_index - 1);
		QuickSort(A, root_index + 1, high);

	}
	
}




int main()
{
	int A[6] = { 4,5,6,3,2,1 };
	int n = 6;
		

	for (int i=0;i<n;i++)
	{
		cout << A[i] << " ";
	}
	cout << endl;
	QuickSort(A, 0, n - 1);
	for (int i = 0; i < n; i++)
	{
		cout << A[i] << " ";
	}
	cout << endl;
	return 0;
}

 

 

 简单选择排序

 

 

#include<iostream>
#include<cstdio>
#include<stdlib.h>
#include<vector>
using namespace std;

void Swap3(int& a, int& b)
{
	int temp = a;
	 a = b;
	 b = temp;
}

int main()
{
	int A[6] = { 4,5,6,3,2,1 };
	int n = 6;
	for (int i = 0; i < n - 1; i++)
	{
		int minn = i;
		for (int j = i + 1; j < n; j++)
		{
			if (A[j]<A[minn])
			{
				minn = j;
			}
		}
		if (minn != i)
		{
			Swap3(A[i], A[minn]);

		}
		
	}
	for (int j = 0; j < n; j++)
	{
		cout << A[j] << endl;
	}

	return 0;
}

归并排序:

 

 

 

#include<iostream>
#include<cstdio>
#include<stdlib.h>
#include<vector>
using namespace std;


//借助辅助数组
vector<int>B;
void Merge(int A[],int low,int mid,int high)
{
	int k = low,i=low,j=mid+1;
	while(i <= mid && j <= high)
	{
		if (A[i] < A[j])
		{
			B[k++] = A[i++];
		}
		else
		{
			B[k++] = A[j++];

		}
	}
	while (i <= mid)
	{
		B[k++] = A[i++];
	}
	while (k <= high)
	{
		B[k++] = A[j++];
	}

	for (k = low; k <= high; k++)
	{
		A[k] = B[k];
	}
}

void MergeSort(int A[], int low, int high)
{
	if (low < high)
	{
		int mid = low + (high - low) / 2;
		MergeSort(A, low, mid);
		MergeSort(A, mid+1,high);
		Merge(A, low, mid, high);
	}

}

int main()
{
	int A[6] = { 4,5,6,3,2,1 };
	int n = 6;
	
	B.resize(n);
	MergeSort(A, 0, n - 1);
	for (int i = 0; i < n; i++)
	{
		cout << A[i] << "  ";
	}
	cout << endl;


	return 0;
}

 

基数排序:

桶排序:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/55558.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

测试|Selenium介绍及环境搭建

测试|Selenium介绍及环境搭建 1.Selenium是什么 Selenium是用来做web网站 UI自动化的测试工具/测试框架。 我们这里说的Selenium是Selenium2.0&#xff0c;它由Selenium IDE&#xff0c;Webdriver, Selenium Grid组成。 Selenium IDE是用于Selenium测试的完成集成开发环境&…

主流开源监控系统一览

减少故障有两个层面的意思&#xff0c;一个是做好常态预防&#xff0c;不让故障发生&#xff1b;另一个是如果故障发生&#xff0c;要能尽快止损&#xff0c;减少故障时长。而监控的典型作用&#xff0c;就是帮助我们发现及定位故障&#xff0c;这两个环节对于减少故障时长至关…

使用vscode进行远程开发服务器配置

1.下载vscode 2.给vscode 安装python 和 remote ssh插件 remote—SSH扩展允许您使用任何具有SSH服务器的远程机器作为您的开发环境。 3.安装remote-SSH插件之后&#xff0c;vscode左侧出现电脑图标&#xff0c;即为远程服务&#xff0c;按图依次点击&#xff0c;进行服务器配置…

Redis-基于内存的key-value结构数据库

读写性高&#xff0c;适合存储热点性高的数据 也称为结构化的NoSql数据库 redis依赖环境&#xff1a;gcc NoSql 非关系型数据库&#xff0c;是关系型数据库的补充 关系型(RDBMS)非关系型(NoSql)MySqlRedisOracleMongo dbDB2MemCachedSQLServer 常用命令 Redis 教程_redi…

机器学习深入浅出

机器学习是一种人工智能的分支&#xff0c;它使用算法和数学模型来让计算机自主学习数据并做出预测和决策。这种技术正在被广泛应用于各种领域&#xff0c;包括自然语言处理、计算机视觉、语音识别、医学诊断和金融预测等。在本篇博客中&#xff0c;我们将介绍机器学习的基本概…

踩坑(5)整合kafka 报错 java.net.UnknownHostException: 不知道这样的主机

java.net.UnknownHostException: 不知道这样的主机。 (5c0c3c629db9)at java.base/java.net.Inet6AddressImpl.lookupAllHostAddr(Native Method) ~[na:na]at java.base/java.net.InetAddress$PlatformNameService.lookupAllHostAddr(InetAddress.java:933) ~[na:na]at java.ba…

【Spring Boot】请求参数传json对象,后端采用(pojo)CRUD案例(102)

请求参数传json对象&#xff0c;后端采用&#xff08;pojo&#xff09;接受的前提条件&#xff1a; 1.Spring Boot 的启动类加注解&#xff1a;EnableWebMvc 2.Spring Boot 的控制层接受参数采用&#xff1a;RequestBody Spring Boot 启动类&#xff1a;加注解&#xff1a;En…

论文阅读 - Few-shot Network Anomaly Detection via Cross-network Meta-learning

论文链接&#xff1a;https://arxiv.org/pdf/2102.11165.pdf 目录 摘要&#xff1a; 引言 问题定义 方法 Graph Deviation Networks Cross-network Meta-learning 摘要&#xff1a; 网络异常检测旨在找到与绝大多数行为显着不同的网络元素&#xff08;例如节点、边、子图…

数字化失败最关键原因是是老板问题,技术问题还是产品问题?

大家都知道失败率高达80%&#xff0c;这太夸张了&#xff0c;ERP导入都没有这个失败率&#xff0c;那到底为什么呢&#xff1f;​ 数字化失败的最关键原因可能因具体环境和情况而异。题主提到的每个因素&#xff08;老板问题、技术问题和产品问题&#xff09;都可能以不同的方…

Java三大特征之继承【超详细】

文章目录 一、继承概念二、继承的语法三、父类成员访问3.1子类中访问父类的成员变量3.2子类和父类成员变量同名3.3子类中访问父类的成员方法 四、super关键字五、子类构造方法六、super和this七、再谈初始化八、protected 关键字九、继承方式十、final 关键字十一、继承与组合 …

IntelliJ IDEA快捷键大全 + 动图演示!

一、构建/编译 Ctrl F9&#xff1a;构建项目该快捷键&#xff0c;等同于菜单【Build】—>【Build Project】 执行该命令后&#xff0c;IntelliJ IDEA 会编译项目中所有类&#xff0c;并将编译结果输出到out目录中。IntelliJ IDEA 支持增量构建&#xff0c;会在上次构建的基…

GC 深入(小白,对gc有一个进一步的了解)

垃圾回收器的搭配 一般固定 一般这年轻代垃圾回收器&#xff0c;老年代垃圾回收器&#xff0c;如上图搭配着使用 1.8呢默认就是最后边那哥俩 jvm调优 一个就是增加吞吐量 一个就是减少STW的时间。 三色标记算法&#xff08;理解根可达算法&#xff09; 并发的可达性分析 有…

Nacos配置中心设置Mongodb

目录 1.common模块导入nacos config依赖 2.common模块新建bootstrap.yaml 3.在自己的模块导入common模块依赖 4.打开nacos新建配置&#xff0c;发布 5.运行服务并测试 效果&#xff1a;在部署完成后&#xff0c;其他人可以自动连接到你本地mongoDB数据库&#xff0c;无需再…

小程序原生实现左右锚点联动

效果 wxml <view classbox><scroll-view scroll-y scroll-with-animation style"width:25%"><view classnav><view wx:for"{{navList}}" wx:keyindex class"title {{index active ?select:}}"data-index{{index}} bin…

Day02-作业(JavaScriptVue)

作业1&#xff1a;实现5秒之后&#xff0c;当前页面直接跳转到官网首页&#xff08;首页地址&#xff1a;https://www.itcast.cn&#xff09; 提示&#xff1a; 5秒之后&#xff0c;才触发某一个动作 素材&#xff1a; <!DOCTYPE html> <html lang"en"&g…

基于Amoeba读写分离(三十六)

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 目录 前言 一、概述 二、实验&#xff1a; 总结 前言 今天要学的是基于Amoeba读写分离。Amoeba是一个开源的关系型数据库管理系统&#xff0c;它支持读写分离的架构。在Amoe…

使用DeferredResult来设计异步接口

文章目录 DeferredResult 介绍思路Demo搭建1.定义一个抽象的请求体2.定义一个接口返回体3.定义一个接口请求体继承抽象类AsynTaskBaseRequest<T<T>>4.定义seveice类&#xff0c;并声明一个异步方法&#xff08;Async注解&#xff09;5.定义一个返回DeferredResult的…

一篇文章带你搞懂Java多态的概念、优点、实现多态的方式、以及不同方式的区别

一篇文章带你搞懂Java多态的概念、优点、使用场景 基本概念 ​ **多态&#xff08;Polymorphism&#xff09;是面向对象编程的一个重要特性&#xff0c;它指的是同一个行为具有多个不同表现形式或形态的能力。**它允许我们使用父类的引用变量来引用子类的对象&#xff0c;并根…

SpringBoot第29讲:SpringBoot集成MySQL - MyBatis-Plus代码自动生成

SpringBoot第29讲&#xff1a;SpringBoot集成MySQL - MyBatis-Plus代码自动生成 本文是SpringBoot第29讲&#xff0c;主要介绍 MyBatis-Plus代码自动生成&#xff0c;以及产生此类代码生成工具的背景和此类工具的基本实现原理。 文章目录 SpringBoot第29讲&#xff1a;SpringBo…

STM32(HAL)串口中断接收

目录 1、简介 2 基础配置 2.1.1 SYS配置 2.1.2 RCC配置 2.2 串口外设配置 2.3 项目生成 3、KEIL端程序整合 1、简介 本文对HAL串口中断函数进行介绍。 2 基础配置 2.1.1 SYS配置 2.1.2 RCC配置 2.2 串口外设配置 2.3 项目生成 3、KEIL端程序整合 首先在main.c文件中进行…