/// <summary> /// 节点 /// </summary> /// <typeparam name="T"></typeparam> public class LinkedListNode<T> { public LinkedListNode(T value) { this.Value = value; } public T Value { get; private set; }//值 /// <summary> /// 后一个节点 /// </summary> public LinkedListNode<T> Next { get; internal set; } /// <summary> /// 前一个节点 /// </summary> public LinkedListNode<T> Prev { get; internal set; } }
public class LinkedList<T> : IEnumerable<T> { public LinkedListNode<T> First { get; private set; } public LinkedListNode<T> Last { get; private set; } public LinkedListNode<T> AddLast(T node) { var newNode = new LinkedListNode<T>(node); if(First == null) { First = newNode; Last = First; } else { LinkedListNode<T> previous = Last; Last.Next = newNode; Last = newNode; Last.Prev = previous; } return newNode; } public IEnumerator<T> GetEnumerator() { LinkedListNode<T> current = First; while (current!=null) { yield return current.Value; current = current.Next; } } IEnumerator IEnumerable.GetEnumerator() { return GetEnumerator(); } }
static void Main(string[] args) { try { Console.WriteLine("**********************LinkedList<int>*********************"); var list1 = new LinkedList<int>(); list1.AddLast(1); list1.AddLast(3); list1.AddLast(5); list1.AddLast(7); foreach (var item in list1) { Console.WriteLine(item); } Console.WriteLine("*********************LinkedList<string>**********************"); var list2 = new LinkedList<string>(); list2.AddLast("2"); list2.AddLast("aaaa"); list2.AddLast("bbbbb"); list2.AddLast("cccc"); foreach (var item in list2) { Console.WriteLine(item); } } catch (Exception ex) { Console.WriteLine("程序出现错误:" + ex.Message); } Console.ReadKey(); }