Implements the LinkedList data structure : Your LinkedList « Collections Data Structure « C# / C Sharp

Home
C# / C Sharp
1.2D Graphics
2.Class Interface
3.Collections Data Structure
4.Components
5.Data Types
6.Database ADO.net
7.Date Time
8.Design Patterns
9.Development Class
10.Event
11.File Stream
12.Generics
13.GUI Windows Form
14.Internationalization I18N
15.Language Basics
16.LINQ
17.Network
18.Office
19.Reflection
20.Regular Expressions
21.Security
22.Services Event
23.Thread
24.Web Services
25.Windows
26.Windows Presentation Foundation
27.XML
28.XML LINQ
C# Book
C# / C Sharp by API
C# / CSharp Tutorial
C# / CSharp Open Source
C# / C Sharp » Collections Data Structure » Your LinkedListScreenshots 
Implements the LinkedList data structure
Implements the LinkedList data structure


using System;

class Node {
  internal Object data;
  internal Node next;
 
  public Node(Object o, Node n){
    data = o;
    next = n;
  }
}
public class LinkedList {
  private Node head;
  private Node previous;
  private Node current;
  
  public LinkedList() {
    head = null;
    previous = null;
    current = null;
  }
  public bool IsEmpty() {
    return head == null;
  }
  public void Insert(Object o) {
    Node n = new Node(o,current);
    if (previous == null)
      head = n;
    else 
      previous.next = n;
    current = n;
  }
  public void Remove() {
    if (head != null){
      if (previous == null)
        head = head.next;
      else 
        previous.next = current.next;
      current = current.next;
    }
  }
  public Object GetData(){
    if (current != null
      return current.data;
    return null;
  }
  public bool AtEnd() {
    return current == null;
  }
  public void Advance(){
    if (!AtEnd()){
      previous = current;
      current = current .next;
    }
  }
  public void Reset() {
    previous = null;
    current = head;
  }
  public void Display() {
    Reset();
    if (head != null
      do {
        Console.WriteLine("   {0}", GetData());
        Advance();
      }while (!AtEnd());
  }    
  public static void Main() {
    LinkedList list = new LinkedList();
    Console.WriteLine("Is Empty {0}",list.IsEmpty());
    list.Insert("A");
    list.Insert("B");
    list.Insert("C");
    Console.WriteLine("The original list is:");
    list.Display();
    list.Reset();
    list.Advance();
    Console.WriteLine("The current element is {0}",list.GetData());
    list.Remove();

    list.Display();
  }
}
           
       
Related examples in the same category
java2s.com  |  | Contact Us | Privacy Policy
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.