C#单向链表实现非升序插入方法:用LinkedList<int>链表类 vs 自定义单向链表类及非升序插入方法

本文主要是介绍C#单向链表实现非升序插入方法:用LinkedList<int>链表类 vs 自定义单向链表类及非升序插入方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一、涉及到的知识点

1.非升序插入的定义

2. 非升序插入不是随机插入

3.AddLast 方法

二、实例

1.自定义单向链表及非升序插入方法

2.用LinkedList链表类AddLast方法实现非升序插入


一、涉及到的知识点

1.非升序插入的定义

        单向链表是一种数据结构,其中元素以线性方式连接在一起,每个元素都指向下一个元素。非升序插入意味着元素不是按升序(从小到大)插入链表中。相反,元素可以以任何顺序插入链表中,这取决于应用程序的需要。 

2. 非升序插入不是随机插入

        在 C# 单向链表中,非升序插入并不意味着随机插入它意味着根据节点数据的大小,在链表中的适当位置插入新节点,而不是简单地将其插入到链表的末尾

        当使用非升序插入时,新节点会根据其数据大小与现有节点进行比较,然后插入到链表中的正确位置。这意味着新节点的插入位置取决于其数据大小以及链表中现有节点的数据大小。

        以下是 InsertUnAscending 方法的工作原理:

  • 如果链表为空,新节点将作为链表的头节点插入。
  • 如果链表不为空,将使用一个临时节点(temp)从头节点开始遍历链表。
  • 在遍历过程中,将比较新节点的数据与当前节点(temp)的下一个节点的数据大小。如果当前节点的下一个节点的数据小于新节点的数据,将移动到下一个节点。
  • 当找到适当的位置时,将新节点插入到当前节点(temp)的下一个节点之前,然后将新节点的下一个节点设置为当前节点的下一个节点的下一个节点。
  • 最后,将当前节点(temp)的下一个节点设置为新节点。

        这种方法确保了链表中的节点数据保持非升序排列。

3.AddLast 方法

        AddLast 方法是 C# 中 LinkedList<T> 类的一个方法,用于在链表的末尾添加一个元素。当想要将元素按任意顺序添加到链表中时,可以使用此方法。

        以下是 AddLast 方法的语法:

public void AddLast(T value);

        其中,T 是类型参数,表示链表中元素的类型。

二、实例

1.自定义单向链表及非升序插入方法

// 单向链表实现:非升序插入数据的方法
namespace _131_7
{public class Node{public int Data { get; set; }public Node? Next { get; set; }}public class LinkedList{private static Node? _head;public LinkedList(){_head = null;}/// <summary>/// 非升序插入节点数据的方法/// 非升序插入意味着元素不是按升序插入链表中/// 相反,元素可以以任何顺序插入链表中/// 具体实现是由程序的需求决定的/// </summary>public static void AddNonAscending(int data){Node newNode = new() { Data = data };if (_head == null){_head = newNode;}else{Node? temp = _head;while (temp.Next != null && temp.Next.Data < data){temp = temp.Next;}newNode.Next = temp.Next;temp.Next = newNode;}}// 遍历链表并打印数据public static void PrintList(){Node? temp = _head;while (temp != null){Console.Write(temp.Data + " ");temp = temp.Next;}Console.WriteLine();}}class Program{static void Main(string[] args){ArgumentNullException.ThrowIfNull(args);// 插入元素,顺序不是升序LinkedList.AddNonAscending(11);LinkedList.AddNonAscending(5);LinkedList.AddNonAscending(3);LinkedList.AddNonAscending(4);LinkedList.AddNonAscending(2);LinkedList.AddNonAscending(1);// 遍历链表并打印元素LinkedList.PrintList();}}
}
//运行结果:
/*
11 1 2 3 4 5*/

2.用LinkedList<int>链表类AddLast方法实现非升序插入

// 用LinkedList<int>链表类AddLast方法实现非升序插入
namespace _131_8
{class Program{static void Main(string[] args){ArgumentNullException.ThrowIfNull(args);LinkedList<int>? list = new();// 插入元素,顺序不是升序list.AddLast(5);list.AddLast(3);list.AddLast(1);list.AddLast(4);list.AddLast(2);// 遍历链表并打印元素LinkedListNode<int>? node = list.First;while (node != null){Console.WriteLine(node.Value);node = node.Next;}}}
}
//运行结果:
/*
5
3
1
4
2*/

         从上面的示例中可以看到,元素不是按升序插入链表的。

这篇关于C#单向链表实现非升序插入方法:用LinkedList<int>链表类 vs 自定义单向链表类及非升序插入方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/761480

相关文章

Flutter实现文字镂空效果的详细步骤

《Flutter实现文字镂空效果的详细步骤》:本文主要介绍如何使用Flutter实现文字镂空效果,包括创建基础应用结构、实现自定义绘制器、构建UI界面以及实现颜色选择按钮等步骤,并详细解析了混合模... 目录引言实现原理开始实现步骤1:创建基础应用结构步骤2:创建主屏幕步骤3:实现自定义绘制器步骤4:构建U

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

Android实现定时任务的几种方式汇总(附源码)

《Android实现定时任务的几种方式汇总(附源码)》在Android应用中,定时任务(ScheduledTask)的需求几乎无处不在:从定时刷新数据、定时备份、定时推送通知,到夜间静默下载、循环执行... 目录一、项目介绍1. 背景与意义二、相关基础知识与系统约束三、方案一:Handler.postDel

在.NET平台使用C#为PDF添加各种类型的表单域的方法

《在.NET平台使用C#为PDF添加各种类型的表单域的方法》在日常办公系统开发中,涉及PDF处理相关的开发时,生成可填写的PDF表单是一种常见需求,与静态PDF不同,带有**表单域的文档支持用户直接在... 目录引言使用 PdfTextBoxField 添加文本输入域使用 PdfComboBoxField

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

C#如何调用C++库

《C#如何调用C++库》:本文主要介绍C#如何调用C++库方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录方法一:使用P/Invoke1. 导出C++函数2. 定义P/Invoke签名3. 调用C++函数方法二:使用C++/CLI作为桥接1. 创建C++/CL

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

Python位移操作和位运算的实现示例

《Python位移操作和位运算的实现示例》本文主要介绍了Python位移操作和位运算的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 位移操作1.1 左移操作 (<<)1.2 右移操作 (>>)注意事项:2. 位运算2.1