【发布时间】:2020-04-27 14:41:54
【问题描述】:
我的任务是为链表类创建基数排序算法,我有一个对象“Info”,它有 int Year 和 double Price,我需要使用基数排序按 Year 对链表进行排序。
class Info
{
public int Year { get; set; }
public double Price { get; set; }
public Info() { }
public Info(int y, double p)
{
Year = y;
Price = p;
}
}
class Node
{
public Info Data { get; set; }
public Node Next { get; set; }
public Node(Info data, Node adress)
{
Data = data;
Next = adress;
}
}
class LinkedList
{
private Node First;
private Node Last;
private Node Current;
public LinkedList()
{
First = null;
Last = null;
Current = null;
}
}
我已经从这个site 中采用了整数的基数排序算法。问题是,我不知道如何修改它以使用我的链接类。
static void Sort(int[] arr)
{
int temp = 0;
int i, j;
int[] tmp = new int[arr.Length];
for (int shift = 31; shift > -1; --shift)
{
j = 0;
for (i = 0; i < arr.Length; ++i)
{
bool move = (arr[i] << shift) >= 0;
if (shift == 0 ? !move : move)
arr[i - j] = arr[i];
else
tmp[j++] = arr[i];
}
Array.Copy(tmp, 0, arr, arr.Length - j, j);
}
}
如何使它与我的链接类一起工作?
【问题讨论】:
标签: c# singly-linked-list radix-sort