图解基础排序算法(冒泡、插入、选择)(山东大学实验二)

news2025/1/9 1:59:14

 

目录

⚽前言:

🏐 冒泡排序:

设定:

分类:

起源:

图解冒泡:

图中绿色:

图中橙色:

整体思路:

交换思路:

核心代码: 

🏀 图解插入:

设定:

插入思路:

整体思路:

核心代码:

🥎图解选择: 

设定:

整体思路:

核心代码: 

🎱山东大学实验二完整代码: 


前言:

冒泡、插入、选择排序的都是最基础的排序算法。其时间复杂度、空间复杂度都较高,但是学起来相对容易,非常适合新手入门学习。并且里面所蕴含的思想也是非常深刻,值得我们细细体味!下面就让我们逐个进入吧。

 冒泡排序:

设定:

首先不妨设定我们需要实现的是从小到大的排序

分类:

冒泡分为两种:一、前向后  二、后向前。

起源:

让我们先来想想水中的气泡是如何从水底浮上来的。是不是从最底下然后逐渐慢慢的向上浮动,直到最终露出水面。那如果有很多气泡呢?那是不是肯定是最轻的气泡先浮上来,然后最重的气泡排在后面再浮上来。这个生活常识就是我们冒泡排序的起源。

图解冒泡:

图中绿色:

在一次次变动的就是每一趟下的冒泡子排序,其目的是为了选出目前待排序的数中最大的一个。

图中橙色:

是每一轮冒泡子排序下得到的最大结果。

整体思路:

不难发现每一轮子排序我们都将得到一个待排序中的最大数。也就是说第一轮得到所有数中的最大值。然后第二轮得到所有数中的次大值(因为此时最大值不参与排序),第三轮得到第三大值。如此循环n-1次,最后完成排序。

交换思路:

每次选择两个数,前面的与后面的比较,若前面大后面小则两者交换。第一次选择1、2数,第二次选择2、3数,第三次选择3、4数,如此重复。如图中的绿色不停比较交换所体现的

核心代码: 

        cout<<"Bubble Sort"<<endl;
        for(int i=0;i<num;i++){
            for(int j=num-1;j>i;j--){
                if(a[j]<a[j-1])
                swap(a[j],a[j-1]);
            }
        }
        for(int i=0;i<num-1;i++){
            cout<<a[i]<<',';
        }
        cout<<a[num-1]<<endl;

时间复杂度:最坏情况:O(N^2)
      最好情况:O(N)
空间复杂度:O(1)

 插入排序:

设定:

首先不妨设定我们需要实现的是从小到大的排序

插入思路:

假如我们有一个有序的序列,现在要将一个数插入这个序列中要求序列仍然有序。那么我们就要从第一个数开始和待插入数进行比较,如果第一个数小于待插入数,说明这个数可能还要插入到后面。于是我们再看第二个数和插入数的大小关系,重复上面的操作。直到我们遇到一个数大于待插入数,那么此时待插入数必然是插入在这个数的前一个,于是我们实现插入。

整体思路:

整体思路就是进行多次前面提到的插入过程。

橙色:已经有序的序列

绿色:待插入有序序列的数 

蓝色:本轮未轮到插入的序列,后续需要插入 

再来个动图:

核心代码:

        cout<<"Insert Sort"<<endl;
        int res[19]={0};
        for(int i=0;i<num;i++){
            int j=0;
            for(j=i-1;j>=0;j--){
                if(a[i]<res[j])
                    res[j+1]=res[j];
                else
                    break;
            }
            res[j+1]=a[i];
        }
        for(int i=0;i<num-1;i++){
            cout<<res[i]<<',';
        }
        cout<<res[num-1]<<endl;

选择排序: 

设定:

首先不妨设定我们需要实现的是从小到大的排序

整体思路:


每次从待排序列中选出一个最小值,然后放在序列的起始位置,直到全部待排数据排完即可。
实际上,我们可以一趟选出两个值,一个最大值一个最小值,然后将其放在序列开头和末尾,这样可以使选择排序的效率快一倍。

橙色:已经完成的有序的序列

红色:不停在找待排序序列中最小的,找到后就和最前面的蓝色的数进行交换

核心代码: 

        cout<<"Select Sort"<<endl;
        int res[19]={0};
        int x=0;
        for(int i=0;i<num;i++){
            int min=INT_MAX;
            int pos=0;
            for(int j=0;j<num;j++){
                if(min>a[j]){
                    min=a[j];
                    pos=j;
                }
            }
            a[pos]=INT_MAX;
            res[x++]=min;
        }
        for(int i=0;i<num-1;i++){
            cout<<res[i]<<',';
        }
        cout<<res[num-1]<<endl;

山东大学实验二完整代码: 

#include<iostream>
using namespace std;

void multiSelect(int a[],int sel,int num){
    switch (sel)
    {
    case 1:{
        cout<<"Bubble Sort"<<endl;
        for(int i=0;i<num;i++){
            for(int j=num-1;j>i;j--){
                if(a[j]<a[j-1])
                swap(a[j],a[j-1]);
            }
        }
        for(int i=0;i<num-1;i++){
            cout<<a[i]<<',';
        }
        cout<<a[num-1]<<endl;
        break;
    }
    case 2:{
        cout<<"Insert Sort"<<endl;
        int res[19]={0};
        for(int i=0;i<num;i++){
            int j=0;
            for(j=i-1;j>=0;j--){
                if(a[i]<res[j])
                    res[j+1]=res[j];
                else
                    break;
            }
            res[j+1]=a[i];
        }
        for(int i=0;i<num-1;i++){
            cout<<res[i]<<',';
        }
        cout<<res[num-1]<<endl;
        break;
    }
    case 3:{
        cout<<"Select Sort"<<endl;
        int res[19]={0};
        int x=0;
        for(int i=0;i<num;i++){
            int min=INT_MAX;
            int pos=0;
            for(int j=0;j<num;j++){
                if(min>a[j]){
                    min=a[j];
                    pos=j;
                }
            }
            a[pos]=INT_MAX;
            res[x++]=min;
        }
        for(int i=0;i<num-1;i++){
            cout<<res[i]<<',';
        }
        cout<<res[num-1]<<endl;
        break;
    }

    default:
        break;
    }
}

int main(){
    cout<<"Input"<<endl;
    int a[19]={0};
    int num=0;
    for(int i=0;i<18;i++){
        int t=0;
        cin>>t;
        if(t==0)
            break;
        else{
            a[i]=t;
            num++;
        }
    }
    cout<<"1-Bubble Sort,2-Insert Sort,3-Select Sort"<<endl;
    int sel=0;
    cin>>sel;
    cout<<"Output"<<endl;
    multiSelect(a,sel,num);
    cout<<"End"<<endl;
}

最后求点赞啦: 

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

怎么在桌面查看备忘录新的提醒事项?方法教程

在这个信息爆炸的时代&#xff0c;我们每天都面临着无数的任务和提醒。作为一名忙碌的职场人&#xff0c;我经常需要依赖备忘录来记录重要的待办事项&#xff0c;以免遗漏。备忘录&#xff0c;就像我生活中的小助手&#xff0c;帮我记下工作会议、生日提醒、购物清单等等&#…

2.3数据链路层02

2.3 数据链路层 2.3.5 以太网 1、以太网概念 以太网是一种计算机局域网技术。IEEE&#xff08;电气与电子工程师协会&#xff1a;Institute of Electrical and Electronics Engineers&#xff09;组织的IEEE802.3标准制定了以太网的技术标准&#xff0c;它规定了包括物理层的…

matlab行操作快?还是列操作快?

在MATLAB中&#xff0c;通常情况下&#xff0c;对矩阵的列进行操作比对行进行操作更有效率。这是因为MATLAB中内存是按列存储的&#xff0c;因此按列访问数据会更加连续&#xff0c;从而提高访问速度。 一、实例代码 以下是一个简单的测试代码&#xff0c; % 测试矩阵大小 ma…

RK3566RK3568安卓11隐藏状态栏带接口

文章目录 前言一、创建全局变量二、设置应用添加隐藏导航栏按钮三、添加按钮功能四、动态隐藏还有显示功能五、创建系统导航栏广播接口总结 前言 关于Android系统的状态栏&#xff0c;不同的客户有不同的需求: 有些客户需要永久隐藏状态栏&#xff0c;有些客户需要在设置显示中…

鸿蒙 ArkUI - 常用组件和布局

目录 一、组件 1.按钮 2.单选框 3.切换按钮 4.进度条 5.文本 6.文本输入框 二、布局方式 1.线性布局 2.层叠布局 3.弹性布局 4.网格布局 一、组件 ArkUI有丰富的内置组件&#xff0c;包括文本、按钮、图片、进度条、输入框、单选框、多选框等。我们还可以将基础组件…

装饰器模式介绍

目录 一、装饰器模式介绍 1.1 装饰器模式定义 1.2 装饰器模式原理 1.2.1 模式类图 1.2.2 模式角色说明 1.2.3 举例代码 二、装饰器模式的应用 2.1 需求说明 2.2 需求实现 2.2.1 类图 2.2.2 类图说明 2.2.3 具体实现 2.2.3.1 DataLoader类 2.2.3.2 BaseFileDataLoa…

Spring使用注解管理Bean

引入lib包 Spring对Bean管理的常用注解 Component组件(作用在类上) Spring中提供了Component的三个衍生注解:(功能在目前为止是一致的) Controller WEB层 Service 业务层 Repository 持久层 属性注入的注解:(使用注解注入的方式,可以不用提供set方法) Value 用于注入普…

新增PostgreSQL数据库管理功能,1Panel开源面板v1.9.3发布

2024年1月15日&#xff0c;现代化、开源的Linux服务器运维管理面板1Panel正式发布v1.9.3版本。 在这一版本中&#xff0c;1Panel新增了PostgreSQL数据库管理功能&#xff0c;并且支持设置PHP运行环境扩展模版。此外&#xff0c;我们进行了30多项功能更新和问题修复。1Panel应用…

6个免费好用的 PDF 文件加密软件 [Windows Mac]

加密 PDF 文件使您能够保护它们免受未经授权的访问。当重要信息处于危险之中时&#xff0c;黑客可以访问电子文档。 考虑到它们很容易被黑客入侵&#xff0c;您需要迅速采取行动。避免这种情况的方法之一是使用更适合您需要的 PDF 加密软件。 有很多选项可供选择&#xff0c;…

Linux中DCHP与时间同步

目录 一、DHCP &#xff08;一&#xff09;工作原理 1.获取 2.续约 &#xff08;二&#xff09;分配方式 &#xff08;三&#xff09;服务器配置 1.随机地址分配 2.固定地址分配 二、时间同步 &#xff08;一&#xff09;ntpdate &#xff08;二&#xff09;chrony …

智云谷再获资本市场青睐,完成数千万元A+轮融资

近日&#xff0c;深圳前海智云谷科技有限公司&#xff08;以下简称“智云谷”&#xff09;完成数千万元A轮融资&#xff0c;本轮融资由青松基金独家投资&#xff0c;多维资本担任独家融资财务顾问。本轮融资资金将用于扩大新技术研发投入、智能工厂扩产、加速产品交付&#xff…

openpose环境搭建

编程如画&#xff0c;我是panda&#xff01; 最近学习要用要openpose&#xff0c;配了三天的环境&#xff0c;快疯了&#xff0c;踩了很多坑&#xff0c;在这里和大家分享一下 目录 前言 一、安装openpose 二、运行openpose 三、常见的两个错误 1. No module named pyopen…

深度学习论文解读分享之diffGrad:一种卷积神经网络优化方法

IEEE TNNLS 2020&#xff1a;diffGrad: 一种卷积神经网络优化方法 题目 diffGrad: An Optimization Method for Convolutional Neural Networks 作者 Shiv Ram Dubey , Member, IEEE, Soumendu Chakraborty , Swalpa Kumar Roy , Student Member, IEEE, Snehasis Mukherjee…

leetcode234. 回文链表

题目 给你一个单链表的头节点 head &#xff0c;请你判断该链表是否为回文链表。如果是&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 示例 1&#xff1a; 输入&#xff1a;head [1,2,2,1] 输出&#xff1a;true示例 2&#xff1a; 输入&#xff1a;hea…

西米支付:到底什么是NFT(数字藏品支付通道)(NFT支付通道)

NFT到底指的是什么呢&#xff1f; 数字藏品的实际意义在于它们打破了传统艺术品的物质形态束缚。数字藏品可以通过虚拟现实和区块链技术进行创作、展示和交易。它们不仅可以满足人们对艺术品的审美需求&#xff0c;还可以成为一种投资和资产保值增值的方式。数字藏品的实际意义…

线控底盘新玩家凶猛!这家企业的ONE-BOX产品正式量产下线

高工智能汽车获悉&#xff0c;12月27日&#xff0c;威肯西科技宣布旗下ONE-BOX线控制动产品--液压解耦制动系统HDBS实现量产下线。该产品将与多个汽车品牌签署量产及定点协议&#xff0c;预计年产量达到60万套。 据了解&#xff0c;作为耀宁科技集团的一级子公司&#xff0c;威…

Javascript 下载方法分享

一、引言 JavaScript是一种广泛使用的编程语言&#xff0c;用于增强网页交互性和动态功能。然而&#xff0c;有时我们需要将JavaScript代码下载并部署到本地服务器或离线环境中。本文将分享一些常用的JavaScript下载方法。 二、直接下载JavaScript文件 手动下载&#xff1a;…

机器学习-决策树

1、什么是决策树&#xff1f; 一种描述概念空间的有效的归纳推理办法。基于决策树的学习方法可以进行不相关的多概念学习&#xff0c;具有简单快捷的优势&#xff0c;已经在各个领域取得广泛应用。 决策树是一种树型结构&#xff0c;其中每个内部结点表示在一个属性上的测试&a…

徐州数字孪生元宇宙赋能工业智能制造,助力传统制造业数字化转型

徐州数字孪生元宇宙赋能工业智能制造&#xff0c;助力传统制造业数字化转型。在徐州市制造业企业数字化转型的过程中&#xff0c;数字孪生技术的应用已经取得了显著成效。一方面&#xff0c;企业的生产效率得到了显著提高&#xff0c;产品质量也得到了有效保障。另一方面&#…

项目管理中,怎么进行项目过程管理?

项目经理在项目管理中会遇到许多问题&#xff0c;其中最令人头痛的莫过于项目计划执行不到位&#xff0c;进度难以跟踪&#xff0c;项目延期严重。这些问题导致项目计划看似存在&#xff0c;但实际上与无计划相差无几。 对于项目团队内部&#xff0c;项目经理常常抱怨团队成员…