数据结构 - 排序算法

news2024/9/28 16:25:11

一.冒泡排序

/**
 * @description:            冒泡排序
 * @param - a       :       要进行排序的数组的指针
 * @param - length  :       数组中元素的个数
 * @return          :       无
*/
void Bubble_sort(int *a,int length)
{
    int temp,i,j;

    for(i = 0;i < length -1;i++)
    {
        for(j = 0;j < length-1-i;j++)
        {
            /* 把小的交换到前面来 */
            if(a[j] > a[j+1])
            {
                temp = a[j+1];
                a[j+1] = a[j];
                a[j] = temp;
            }
        }
    }
}

二.直接插入排序

/**
 * @description:            直接插入排序算法
 * @param - a       :       要进行排序的数组的指针
 * @return          :       无
*/
void Seqsort(int *a)
{
    /* i 用于表示无序部分的第一个元素的下标 , j 用于表示有序部分的最后一个元素的下标 , temp 用于保存中间值 */
    int i,j,temp;

    /* 1.初始情况 , 将数组的 a[0] 与后面的元素分开,即 i 从 1 开始 */
    for(i = 1;i < N;i++)
    {
        temp = a[i];
        /* 2. j 指向已排好序部分的最后一个元素的下标 */
        for(j = i-1;j >= 0;j--)
        {   
            /* 若 a[i] < a[j] 则 a[j] 向后移动 */
            if(temp < a[j])
                a[j+1] = a[j];
            
            /* 若 a[i] >= a[j] 则跳出循环 */
            else
                break;
        }
        
        /* 若 a[i] >= a[j] 则 a[j+1] = a[i] */
        a[j+1] = temp;

        Show(a);
        
    }

}

三.shell排序算法 - 对直接插入排序的改进

1.shell排序的步骤

        ①.对序列进行分组,增量为 d

        ②.对每一组 分别 / 交替 直接插入排序

        ③.逐渐减小增量 d

2.图形讲解

3.代码

/**
 * @description:            shell排序
 * @param -a        :       要进行排序的数组的指针
 * @return          :       无
*/
void Shell_sort(int *a)
{
    /* i 用于表示无序部分的第一个元素的下标 , j 用于表示有序部分的最后一个元素的下标 , temp 用于保存中间值 */
    int i,j,temp;
    int d;

    /* 初始化 d = N / 2 , 然后 d 持续减小 */
    for(d = N/2;d > 0;d /= 2)
    {
        /* 1.将数组的同一组元素进行直接插入排序 */
        for(i = d;i < N;i++)
        {
            temp = a[i];
            /* 2. j 指向已排好序部分的最后一个元素的下标 ,同一组内的元素每两个相邻的元素之间的距离为 d */
            for(j = i-d;j >= 0;j -= d)
            {   
                /* 若 a[i] < a[j] 则 a[j] 向后移动 , 移动的步长为 d */
                if(temp < a[j])
                    a[j+d] = a[j];
                
                /* 若 a[i] >= a[j] 则跳出循环 */
                else
                    break;
            }
            
            /* 若 a[i] >= a[j] 则 a[j+d] = a[i] */
            a[j+d] = temp;
        }
        Show(a);
    }

}

四.快速排序算法

1.快速排序图形讲解

2.代码

        利用 递归 

                ①.经过一趟快速排序后,确认基准位置

                ②.该基准将整个数组分为左右两部分

                ③.分别对左右两部分进行快速排序

/**
 * @description:            一趟的快速排序
 * @param - a       :       要排序的数组的指针
 * @param - i       :       下界元素的下标
 * @param - j       :       上界元素的下标
 * @return          :       基准元素的下标
*/
int Quickpass(int *a,int i,int j)
{
    int temp;

    /* 当上界小于下界时进行一趟的快速排序 */
    /* 1.保存基准的值 */
    temp = a[i];
    while(i < j)
    {
        /* 2.比较 temp 与 a[j] 的大小,若 temp <= a[j] , 则 j-- ,若 temp > a[j] 则将 a[j] 的值赋给 a[i] */
        while(i < j && temp <= a[j])
        {
            j--;
        }
        if(i < j)   //若正常结束循环
        {
            a[i] = a[j];                    //temp > a[j] 则将 a[j] 的值赋给 a[i]
        }

        /* 3.比较 temp 与 a[i] 的大小 , 若 temp >= a[i] , 则 i++ , 若 temp < a[i] , 则将 a[i] 的值赋给 a[j] */
        while(i < j && temp >= a[i])
        {
            i++;
        }
        if(i < j)   //若正常结束循环
        {
            a[j] = a[i];                    //temp < a[i] , 则将 a[i] 的值赋给 a[j]
        }
    }

    /* 4.一趟快速排序结束后 , 将一开始保存的基准的值 temp 重新加入到序列中 */
    a[i] = temp;

    /* 5.返回基准元素的下标 */
    return i;
}



/**
 * @description:            快速排序
 * @param - a       :       要排序的数组的指针
 * @param - low     :       下界元素的下标
 * @param - high    :       上界元素的下标
 * @return          :       无
*/
void Quick_sort(int *a,int low,int high)
{
    int mid;        // mid 用于存储基准的位置

    if(low < high)
    {
        mid = Quickpass(a,low,high);                  //一趟的快速排序
        Show(a);
        Quick_sort(a,low,mid-1);            //基准左边的序列进行快速排序
        Quick_sort(a,mid+1,high);           //基准右边的序列进行快速排序
    }
}

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

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

相关文章

基于SpringBoot+Vue的小儿推拿培训管理系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码 精品专栏&#xff1a;Java精选实战项目…

SSM框架VUE电影售票管理系统开发mysql数据库redis设计java编程计算机网页源码maven项目

一、源码特点 smm VUE电影售票管理系统是一套完善的完整信息管理类型系统&#xff0c;结合SSM框架和VUE、redis完成本系统&#xff0c;对理解vue java编程开发语言有帮助系统采用ssm框架&#xff08;MVC模式开发&#xff09;&#xff0c;系 统具有完整的源代码和数据库&#…

Vue devtools 插件

一、安装 去这下载https://chrome.zzzmh.cn/ 打开chrome的扩展程序 再打开开发模式 把刚才下载的拖到这里 然后把它固定到工具栏 就是这样了。 二、使用 程序通过open on live server后&#xff0c;打开开发者工具&#xff0c;找到vue就可以了。 这是代码 <div id"ap…

C++ 基础入门-命名空间、c++的输入输出、缺省参数、函数重载、引用、内联函数超详细讲解

这篇文章主要对c的学习做一个基础铺垫&#xff0c;方便后续学习。主要通过示例讲解命名空间、c的输入输出cout\cin&#xff0c;缺省参数、函数重载、引用、内联函数&#xff0c;auto关键字&#xff0c;for循环&#xff0c;nullptr以及涉及到的周边知识&#xff0c;面试题等。为…

遍历递归数结构,修改里的disabled值

返回参数中新增字段 disabled,后端给的值为1和2, disabled1时&#xff0c;代表该节点需要置灰&#xff0c;不可选中 现在需要将disabled的值,改为布尔类型; 后端给的数结构是对象类型,tree接收数组类型; 先将对象类型的数据,遍历递归,修改里面的disabled值,最后再加[ ],改为…

Magnific推V2图像生成服务 可直出4K图像

人工智能 - Ai工具集 - 集合全球ai人工智能软件的工具箱网站 近日&#xff0c;AI图像处理领域再迎重大突破&#xff0c;Magnific推出的V2图像生成服务引领行业潮流。此次升级&#xff0c;不仅使Magnific从高端软件跻身为顶级AI图像生成器&#xff0c;更彰显了其在技术创新及用…

html+css+js实现Progress 进度条

实现效果 代码实现 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>progress</title><st…

动手学深度学习(李沐)PyTorch 第 4 章 多层感知机

4.1 多层感知机 隐藏层 我们在 3.1.1.1节中描述了仿射变换&#xff0c; 它是一种带有偏置项的线性变换。 首先&#xff0c;回想一下如 图3.4.1中所示的softmax回归的模型架构。 该模型通过单个仿射变换将我们的输入直接映射到输出&#xff0c;然后进行softmax操作。 如果我们…

5V继电器模块详解(STM32)

目录 一、介绍 二、模块原理 1.原理图 2.引脚描述 3.工作原理介绍 三、程序设计 main.c文件 relay.h文件 relay.c文件 四、实验效果 五、资料获取 项目分享 一、介绍 继电器(Relay)&#xff0c;也称电驿&#xff0c;是一种电子控制器件&#xff0c;它具有控制系统…

力扣75道热门算法题 第一天

1768、交替合并字符串 题解&#xff1a; class Solution {public String mergeAlternately(String word1, String word2) {int m word1.length(),n word2.length();int i 0, j 0; //双指针遍历两个数组StringBuilder sb new StringBuilder(); //生成一个StringBuilder对象…

如何禁止电脑上某个软件运行?电脑设置禁止运行软件的4个方法速成

在日常使用电脑的过程中&#xff0c;可能会遇到需要禁止某些软件运行的情况。 无论是为了防止员工随意使用与工作无关的软件&#xff0c;还是为了管理孩子的电脑使用时间&#xff0c;禁止特定软件运行都是有效的解决方案。 下面介绍4个速成方法&#xff0c;帮你轻松禁止电脑上…

AlmaLinux 9 安装mysql8.0.38

文件下载 https://cdn.mysql.com//Downloads/MySQL-8.0/mysql-8.0.39-linux-glibc2.12-x86_64.tar 选择合适系统版本 下载后解压 tar -xvf mysql-8.0.39-linux-glibc2.12-x86_64.tar解压后里面有三个文件夹 使用mysql-8.0.39-linux-glibc2.12-x86_64.tar.xz即可&#xff0c…

《牧神记》PV初体验,玄机科技再塑经典国漫

2024年9月26日《牧神记》动画版在Bilibili正式宣布定档于10月27日&#xff0c;并在各大社交媒体平台上发布系列精美海报&#xff0c;瞬间点燃了广大动漫爱好者的热情与期待&#xff01;作为一个长期关注国产动画的漫迷&#xff0c;我对玄机科技的作品一直抱有很高的期待&#x…

Ubuntu 16.04安装填坑记录

一. 问题描述&#xff1a; &#xff08;1&#xff09;Ubuntu 16.04使用USB启动盘安装时&#xff0c;出现"try ubuntu without installation"或“install ubuntu”选择&#xff0c;Enter选择安装后&#xff0c;显示器黑屏无任何显示。 原因分析&#xff1a; 显示黑…

26:WDG看门狗

WDG看门狗 1、看门狗的简介2、独立看门狗3、窗口看门狗4、独立看门狗代码5、窗口看门狗代码 1、看门狗的简介 1、看门狗的作用是监控程序的运行状态。当程序因为设计漏洞、硬件故障、电磁干扰等原因&#xff0c;出现卡死或跑飞现象时&#xff0c;看门狗能及时复位程序&#xf…

现行经济下,兜底的生存方式是什么?

最近在网上看到一个问题&#xff0c;在经济下行的时候&#xff0c;兜底的生存方式是什么,看到之后&#xff0c;就随便写写。 在现在的经济环境下&#xff0c;看看网上的裁员、降薪信息 到底什么才是兜底的生存方式&#xff0c;原来认识的人&#xff0c;包括我自己也在想失业后…

知识付费APP开发指南:基于在线教育系统源码的技术详解

本篇文章&#xff0c;我们将探讨基于在线教育系统源码的知识付费APP开发的技术细节&#xff0c;帮助开发者和企业快速入门。 一、选择合适的在线教育系统源码 选择合适的在线教育系统源码是开发的关键一步。市场上有许多开源和商业化的在线教育系统源码&#xff0c;开发者需要…

《深度学习》卷积神经网络 数据增强、保存最优模型 原理解析及实例实现

目录 一、数据增强 1、什么是数据增强 2、目的 3、常用的数据增强方法 4、数据预处理 用法&#xff1a; 5、使用数据增强增加训练数据 二、保存最优模型 1、什么是保存最优模型 2、定义CNN模型 运行结果&#xff1a; 3、设置训练模式 4、设置测试模式、保存最优模…

影院管理新篇章:小徐的Spring Boot应用

第三章 系统分析 整个系统的功能模块主要是对各个项目元素组合、分解和更换做出对应的单元&#xff0c;最后在根据各个系统模块来做出一个简单的原则&#xff0c;系统的整体设计是根据用户的需求来进行设计的。为了更好的服务于用户要从小徐影城管理系统的设计与实现方面上做出…

羽毛类型检测系统源码分享

羽毛类型检测检测系统源码分享 [一条龙教学YOLOV8标注好的数据集一键训练_70全套改进创新点发刊_Web前端展示] 1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 项目来源AACV Association for the Advancement of Computer Vis…