C#双向链表LinkedList排序实现方法
作者:北风其凉 发布时间:2021-08-19 14:06:16
标签:C#,双向链表,排序
本文实例讲述了C#双向链表LinkedList排序实现方法。分享给大家供大家参考。具体如下:
1.函数
打印链表函数PrintLinkedList 和 排序函数SortLinkedList
注:下面代码中的链表每项都是double类型,如果换做其他的类型或结构,则需要适当修改
/// <summary>
/// 打印链表各结点信息
/// </summary>
/// <param name="ll"></param>
private static void PrintLinkedList(LinkedList<double> ll, string title = "")
{
//打印标题
Console.WriteLine(string.Format("-- {0} --",
string.IsNullOrWhiteSpace(title) ? "打印链表" : title));
//逐个结点打印链表
LinkedListNode<double> lln = ll.First;
int counter = 0;
while (lln != null)
{
Console.WriteLine(string.Format("第 {0} 个结点值为 {1}",
counter++, lln.Value.ToString("#0.0")));
lln = lln.Next;
}
}
/// <summary>
/// 返回一个排序后的链表
/// </summary>
/// <param name="linkedlist">待排序链表</param>
/// <param name="isAsc">true:升序/false:降序</param>
/// <returns></returns>
private static LinkedList<double> SortLinkedList(
LinkedList<double> linkedlist, bool isAsc = true)
{
LinkedList<double> result = new LinkedList<double>();
foreach (double nodevalue in linkedlist)
{
LinkedListNode<double> lln = result.First;
while (true)
{
if (isAsc) //升序排列时情况
{
if (lln == null)
{
result.AddLast(nodevalue);
break;
}
else if (nodevalue <= lln.Value)
{
result.AddBefore(lln, nodevalue);
break;
}
else
{
lln = lln.Next;
}
}
else //降序排列时情况
{
if (lln == null)
{
result.AddLast(nodevalue);
break;
}
else if (nodevalue >= lln.Value)
{
result.AddBefore(lln, nodevalue);
break;
}
else
{
lln = lln.Next;
}
}
}
}
return result;
}
2.Main函数调用
static void Main(string[] args)
{
//测试用数组
double[] array = new double[]
{
3.5, 2.5, 6.2, 8.0, 1.3,
4.6, 5.5, 2.7, 8.4, 9.7
};
//生成链表ll
LinkedList<double> ll = new LinkedList<double>();
for (int i = 1; i < array.Length; i++)
{
ll.AddLast(array[i]);
}
//打印链表ll
PrintLinkedList(ll, "原链表");
//对链表ll进行排序(升序)
ll = SortLinkedList(ll);
//打印排序后的链表ll
PrintLinkedList(ll, "链表(升序)");
//对链表ll进行排序(降序)
ll = SortLinkedList(ll, false);
//打印排序后的链表ll
PrintLinkedList(ll, "链表(降序)");
Console.ReadLine();
}
3.运行结果:
希望本文所述对大家的C#程序设计有所帮助。


猜你喜欢
- Druid动态数据源配置 主要是继承AbstractRoutingDataSource再通过AOP来实现动态数据源切换.下面给大家介绍Dru
- springMVC项目中实现图形验证码功能,可以使用kaptcha来实现,下面是步骤一、引入架包,pom.xml<dependency
- 当使用spring-Boot时,嵌入式Servlet容器通过扫描注解的方式注册Servlet、Filter和Servlet规范的所有 * (
- 本文以实例形式讲述了C#通过反射创建自定义泛型的实现方法,分享给大家供大家参考。具体如下:比如有这样一个泛型:Demo.GenericsSi
- Demo环境JDK8Maven3.6.3springboot2.4.3redis_version:6.2.1仓库地址https://gite
- 遇到的问题解决方法win7:insert键切回win10:fn+insert切回Mac:fn+i 切回来源:https://blog.csd
- windows下使用cmd命令提示符生成java webservice客户端代码,可以使用命令提示符直接生成客户端代码,直接导入到项目中,只
- Bottom SheetBottom Sheet 是 Design Support Library 23.2 版本引入的一个类似于对话框的控
- 在Android Studio 2.1 Preview 3之后,官方开始支持双向绑定了。可惜目前Google并没有在Data Binding
- mysql插件实现原理官网的关键信息参考文档https://mybatis.org/mybatis-3/zh/configuration.h
- 泛型方法是使用类型参数声明的方法,如下所示:static void Swap<T>(ref T lhs, ref T rhs){
- 其实我们在社交网络上面所发出的任何信息, 都希望能够保留下来. 那么如何实现呢?数据持久化数据持久化, 就是将内存中的瞬时数据保存在存储设备
- 先给大家展示效果图,如果感觉还不错,请参考实例代码效果图如下所示:具体代码如下:private void initData() { Bmob
- 带占位符的 URL 是 Spring3.0 新增的功能,该功能在SpringMVC 向 REST 目标挺进发展过程中具有里程碑的意义。通过
- 前言J.U.C是java包java.util.concurrent的简写,中文简称并发包,是jdk1.5新增用来编写并发相关的基础api。j
- 什么是流?流:程序和设备之间连接起来的一根用于数据传输的管道,流就是一根管道。流的分类:四大基本抽象流(输入流,输出流,字符流,字节流)文件
- 前言上周末我们一起分析了ArrayList的源码并进行了一些总结,因为最近在看Collection这一块的东西,下面的图也是大致的总结了Co
- Rmb.javapublic class Rmb { /** *人民币的基本信息和操作 *@auth
- 前言各位小伙伴大家好,我是A哥。IDEA上个较大版本的发布,要追溯到4月份了:时隔近4个月,北京时间2020-07-28深夜,Intelli
- 监听通知Android 中的 AccessibilityService 可以监听通知信息的变化,首先需要创建一个无障碍服务,这个教程可以自行