学习笔记-数据结构-线性表(2024-04-18)- 单向链表选择排序

news2025/1/22 23:36:13

试以单向链表为存储结构实现简单选择排序的算法。

实现递增排序,首先选择一个元素作为第一个比较值,遍历其他所有的元素,如果发现其他元素中有比它小的元素,则交换两个元素,这样每一趟都能找到符合要求的最小值

正经的单向链表排序,不是换数据的那种!
思想是选择排序的思想,但问题在于单链表结构不同于数组的直接交换,需要断链和重新成链等各种操作,稍不留神就直接G了

具体实现步骤如下

  • 初始化指针变量a和b,它们都指向链表的头节点。
  • 外层循环遍历链表,直到节点b是链表中的最后一个节点。
  • 内层循环遍历以节点b为起始的子链表,寻找其中最小的节点d。
  • 如果节点b的值大于节点d的值,说明需要将节点d插入到节点b之前。
  • 根据不同情况进行节点的移动和连接操作:
    • 如果节点d紧跟在节点b后面,分为两种情况:
      • 如果节点b是链表的头节点,则直接将节点d移动到节点b之前,并调整头节点的指针。
      • 如果节点b不是链表的头节点,则将节点d移动到节点b之前,并更新a的next指针。
    • 如果节点b和节点d之间有其他节点,也分为两种情况:
      • 如果节点b是链表的头节点,则将节点d移动到节点b之前,并更新头节点的指针。
      • 如果节点b不是链表的头节点,则将节点d移动到节点b之前,并更新a的next指针。
  • 完成内层循环后,更新a和b的指针,继续下一轮循环,直到整个链表都被排序完成。
  • 最后返回排序后的链表头节点。

下面是C语言写法:

typedef struct Node
{
    int data;
    struct Node *next;
}LinkNode;


LinkNode* selectionSort(LinkNode* head) 
{ 
    LinkNode *a, *b, *c, *d, *r; // 声明指针变量 a, b, c, d, r

    a = b = head; // 初始化指针变量 a, b,它们指向链表头部

    // 当 b 不是最后一个节点时执行循环
    while (b->next) { 

        c = d = b->next; // 初始化指针变量 c, d,它们指向 b 的下一个节点

        // 当 d 指向一个有效节点时执行循环
        while (d) { 

            if (b->data > d->data) { // 如果 b 的值大于 d 的值

                if (b->next == d) { // 如果 d 紧跟在 b 后面

                    if (b == head) { // 如果 b 是链表的头节点

                        // 将 d 移动到 b 的前面
                        b->next = d->next; 
                        d->next = b; 

                        // 交换 b 和 d 的指针
                        r = b; 
                        b = d; 
                        d = r; 

                        c = d; // 更新 c

                        // 更新链表头部
                        head = b; 

                        // 跳到下一个元素,因为它已经是有序的
                        d = d->next; 
                    } 
                    else { // 如果 b 不是链表的头节点

                        // 将 d 移动到 b 的前面
                        b->next = d->next; 
                        d->next = b; 
                        a->next = d; 

                        // 交换 b 和 d 的指针
                        r = b; 
                        b = d; 
                        d = r; 

                        c = d; // 更新 c

                        // 跳到下一个元素,因为它已经是有序的
                        d = d->next; 
                    } 
                } 
                else { // 如果 b 和 d 之间有一些非零节点

                    if (b == head) { // 如果 b 是链表的头节点

                        // 交换 b->next 和 d->next
                        r = b->next; 
                        b->next = d->next; 
                        d->next = r; 
                        c->next = b; 

                        // 交换 b 和 d 的指针
                        r = b; 
                        b = d; 
                        d = r; 

                        c = d; // 更新 c

                        // 跳到下一个元素,因为它已经是有序的
                        d = d->next; 

                        // 更新链表头部
                        head = b; 
                    } 
                    else { // 如果 b 不是链表的头节点

                        // 交换 b->next 和 d->next
                        r = b->next; 
                        b->next = d->next; 
                        d->next = r; 
                        c->next = b; 
                        a->next = d; 

                        // 交换 b 和 d 的指针
                        r = b; 
                        b = d; 
                        d = r; 

                        c = d; // 更新 c

                        // 跳到下一个元素,因为它已经是有序的
                        d = d->next; 
                    } 
                } 
            } 
            else { // 如果 b 的值不大于 d 的值

                // 更新 c 并跳到下一个元素,因为它已经是有序的
                c = d; 
                d = d->next; 
            } 
        } 

        a = b; // 更新 a
        b = b->next; // 更新 b
    } 

    return head; // 返回排序后的链表头部
} 

下面是Java语言写法:


public class Main {
  
    public static class Node {
        int data; 
        Node next; 
    };

    public static Node selectionSort(Node head)
    {
        Node a, b, c, d, r;
        a = b = head;
        while (b.next != null) {
            c = d = b.next;
            while (d != null) {
                if (b.data > d.data) {
                    if (b.next == d) {
                        if (b == head) {
                            b.next = d.next;
                            d.next = b;
                            r = b;
                            b = d;
                            d = r;
                            c = d;
                            head = b;
                            d = d.next;
                        }
                        else {
                            b.next = d.next;
                            d.next = b;
                            a.next = d;
                            r = b;
                            b = d;
                            d = r;
                            c = d;
                            d = d.next;
                        }
                    }
                    else {
                        if (b == head) {
                            r = b.next;
                            b.next = d.next;
                            d.next = r;
                            c.next = b;
                            r = b;
                            b = d;
                            d = r;
                            c = d;
                            d = d.next;
                            head = b;
                        }
                        else {
                            r = b.next;
                            b.next = d.next;
                            d.next = r;
                            c.next = b;
                            a.next = d;
                            r = b;
                            b = d;
                            d = r;
                            c = d;
                            d = d.next;
                        }
                    }
                }
                else {
                    c = d;
                    d = d.next;
                }
            }
            a = b;
            b = b.next;
        }
        return head;
    }

	// 新建Node节点
    static Node newNode(int val)
    { 
        Node temp = new Node(); 
  
        temp.data = val; 
  
        temp.next = null; 
  
        return temp; 
    } 
} 

示例

以 -2-0-0-3-5-1- 单链表为例
由于动态演示图较大,csdn无法上传,请移步至 https://gitee.com/xjk2000/image-storage/blob/master/1.gif
Java代码测试执行:
测试代码
执行结果:
在这里插入图片描述

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

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

相关文章

Turnitin查重时,论文里面的图片会不会被查到?

在撰写论文的时候,论文里面插入几张图片作为观点和数据的阐述在再正常不过了。但是,一旦涉及到论文查重,事情就变得有点复杂了。许多同学早使用Turnitin检测系统(www.checktoo.com)对论文查重时,就常问题到…

记录交叉编译环境配置--海思开发板的 嵌入式nginx和 php的移植

嵌入式 lnmp搭建的记录 一些交叉编译的配置环境思路分享:P:php编译PHP可能遇到的问题configure阶段:Makefile-make阶段:Makefile-make install阶段: N:Nginx 文章比较水,并没有没解决什么实际问…

现货白银保证金交易要先分析趋势

现货白银是保证金交易品种,买卖过程中可能会涉及数十倍的资金杠杆,所以它对投资者的分析水平和交易水平的要求都比较高,所以在进入这个市场之前,投资者需要先学习一些基本的分析方法,当中可以分为基本面和技术面两大流…

2024年外贸独立站建设首选:WordPress引领市场,助力企业出海

随着全球经济的不断融合与发展,越来越多的企业开始关注海外市场,希望通过建设外贸独立站来扩大品牌影响力和销售额。在众多的内容管理系统(CMS)中,WordPress以其强大的功能、丰富的插件资源和用户友好的操作界面&#…

医学临床预测模型发展新趋势-并联式

医学临床预测模型发展新姿势-并联式 现有的预测模型是对单个结局指标进行分类或者回归,得出最终的结论,而辅助医生进行临床决策。众所周知,临床决策过程中,医生通常会考虑多个结局指标来做出最终的决策;临床研究中也通…

多因子模型的因子分组-克隆巴赫α系数

优质博文:IT-BLOG-CN 在建立我们的Alpha模型之前,我们得先知道什么是Alpha?Alpha是一条或者一系列能够预测股票走势的信息资讯组合。而这每一条非随机的信息资讯,我们称之为多因子模型的因子。多因子模型因子的选择需要避免系统性…

苍穹外卖day1--开发环境搭建

整体结构 前端:管理端(Web) 用户端(小程序) 后端:后端服务(Java) 前端工程基于ngnix运行 启动nginx:双击nginx.exe即可启动nginx服务,访问端口号为80 后端…

智慧浪潮下的产业园区:解读智慧化转型如何打造高效、绿色、安全的新产业高地

随着信息技术的飞速发展,智慧化转型已经成为产业园区发展的重要趋势。在智慧浪潮的推动下,产业园区通过集成应用物联网、大数据、云计算、人工智能等先进技术手段,实现园区的智慧化、高效化、绿色化和安全化,从而打造成为新产业高…

网络安全产品---数据库防火墙/审计

数据库防火墙 防火墙的类型繁多,即使下一代防火墙或者说AI防火墙集成功能再多,我觉得waf与数据库防火墙也有其无法被替代的理由,以此记录我对数据库防火墙的理解 what 数据库防火墙是基于数据库协议分析与访问行为控制的数据库安全防护产品…

ZStack教育云计算解决方案入选高质量数字化转型技术解决方案集

近日,中国信通院“铸基计划”《高质量数字化转型技术解决方案(2023年度)》(以下简称“方案集”)发布,云轴科技ZStack智慧教育云计算解决方案入选《高质量数字化转型技术解决方案集》。 为促进数字化转型相…

Kubernetes Pod OOMKilled诊断

Kubernetes Pod OOMKilled诊断 介绍 OOMKilled错误表示容器或pod已被终止,因为它使用的内存多于分配的内存。OOMKilled,通常称为Exit Code 137,是一种源自Linux的错误。OOM(Out of Memory Manager)是Linux系统上的一…

【Flutter】多语言方案二:GetX 版

介绍 多语言方案:GetX版,需要手动自定义字符串引用常量,优点不需要自己管理状态。 目录 介绍运行效果一、安装 GetX二、使用1.语言配置 在lib/core下创建一个language文件夹,文件夹下创建一个local.dart文件2.language文件夹下创…

网络行为分析与异常检测

构建防火墙和使用简单的安全解决方案不足以保护网络免受网络异常或攻击,因为DDoS攻击、未知恶意软件和其他安全威胁一直在上升,改变了网络安全格局。网络管理员必须积极主动地分析网络,获得对网络的完全控制,并全面了解网络流量活…

数据可视化(六):Pandas爬取NBA球队排名、爬取历年中国人口数据、爬取中国大学排名、爬取sina股票数据、绘制精美函数图像

Tips:"分享是快乐的源泉💧,在我的博客里,不仅有知识的海洋🌊,还有满满的正能量加持💪,快来和我一起分享这份快乐吧😊! 喜欢我的博客的话,记得…

Docker Compose 的安装和使用详解

Docker Compose 是 Docker 官方开源的容器编排(Orchestration)项目之一,用于快速部署分布式应用。本文将介绍 Docker Compose 的基本概念、安装流程及使用方法。 简介 Compose 项目是 Docker 官方的开源项目,负责实现对 Docker 容器集群的快速编排。从功能上看,Docker C…

【AI自媒体制作】【AI工具】Midjourney中文站

Midjourney Midjourney中文站, MJ中文站 - 专业AI绘图网站 广场 绘画广场: 包含大量其他用户生成好的图片,可以自由保存。 视频广场: 普通用户目前只支持查看,无法下载 画夹广场: 有很多免费的画夹,比…

对接浦发银行支付(五)-- 主动查询支付结果

一、背景 上一篇我们介绍了支付回调接口的对接情况,当回调出现网络等异常情况,导致用户的支付订单未及时处理或处理失败的时候,商户则需要自己主动向浦发银行发起查询支付结果。 主动查询支付结果,发挥补偿重试的重要作用&#x…

自然语言处理基础面试

文章目录 TF-IDFbag-of-wordsBert 讲道理肯定还得有Transformer,我这边先放着,以后再加吧。 TF-IDF TF(全称TermFrequency),中文含义词频,简单理解就是关键词出现在网页当中的频次。 IDF(全称…

C语言实现贪吃蛇项目(2)

先来看看效果: 20240420_212115 文章目录: 3.项目实现3.0宽字符的打印3.01本地化操作setlocale函数宽字符的打印 3.1贪吃蛇结构的创建和维护3.11贪吃蛇结构的创建3.12贪吃蛇的维护 3.2初始化游戏3.21.打印欢迎界面、隐藏光标和设置窗口大小3.22.绘制地图…

java中File类和输入输出流的用法

目录 针对文件系统进行操作 针对文件内容进行操作 java针对文件操作可以分为两种:1)针对文件系统进行操作,如创建文件,删除文件,创建目录,重命名文件等。 2)针对文件内容进行操作&#xff0c…