C#雙向鏈表LinkedList排序實現方法
更新時間:2015年08月13日 12:11:48 作者:北風其涼
這篇文章主要介紹了C#雙向鏈表LinkedList排序實現方法,涉及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#程序設計有所幫助。
相關文章
使用DateTime的ParseExact方法實現特殊日期時間的方法詳解
本篇文章是對使用DateTime的ParseExact方法實現特殊日期時間的方法進行了詳細的分析介紹,需要的朋友參考下2013-05-05
C#使用MiniExcel實現導入導出數據到Excel/CSV文件
MiniExcel是一個簡單、高效避免OOM的.NET處理Excel查、寫、填充數據的工具,這篇文章主要介紹了C#如何使用MiniExcel實現導入導出數據到Excel/CSV文件,需要的可以參考下2024-02-02
Entity?Framework代碼優(yōu)先(Code?First)模式
這篇文章介紹了Entity?Framework代碼優(yōu)先(Code?First)模式,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-06-06
C#發(fā)送HttpPost請求來調用WebService的方法
在C#中發(fā)送HttpPost請求來調用WebService中的MyAction方法,代碼如下:需要的朋友可以參考一下2013-03-03

