数据结构(C#)--单链表

2007年最后一个月在忙碌度过了,最近在网上下了一本C#版本的数据结构的电子书,正好我也打算在把数据结构在过一遍,刚好可以看这本,还可以提高一下英文的阅读能力。

书名是《DATA STRUCTURES AND ALGORITHMS USING C#》,作者:MICHAEL MCMILLAN

以后我会陆续把这本数的心得发上来,同时也把自己亲手实践过的代码发上来,大家一起学习,一起进步。如果有什么错误,大家可以发邮件或者留言给我。谢谢。由于该书的结构和我们一般教材的结构不是很一样,所以我按照一般教材的顺序,先从链表开始,原书链表是在第十一章才讲的。书中代码有问题的地方我会在注释中标注出来。

 

namespace DataStruct
{
    
//定义单链表的表头
    public class Node
    
{
        
//存储数据,定义为基类,可以存不同类型的数据
        public Object Element;
        
//指向下一个结点的引用
        public Node Link;

        
//构造空结点
        public Node()
        
{
            
this.Element = null;
            
this.Link = null;
        }

        
//带参数的构造器
        public Node(Object element)
        
{
            
this.Element = element;
            
this.Link = null;
        }

    }


    
public class LinkedList
    
{
        
//此处原书有误,不应该设置为peotected,这样会导致结点没有实例化
        public Node Header;
        
public LinkedList()
        
{
            Header 
= new Node("header");
        }


        
//查找链表中的元素
        private Node Find(Object item)
        
{
            Node Current 
= new Node();
            Current 
= Header;
            
//书中此处代码有误
            
//while(Current.header !=item)
            while (Current.Element != item)
            
{
                Current 
= Current.Link;
            }

            
return Current;
        }


        
//在链表中插入元素
        public void InsertNode(Object newItem,Object after)
        
{
            Node Current 
= new Node();
            Node NewNode 
= new Node(newItem);
            Current 
= Find(after);
            
if (Current != null)
            
{
                NewNode.Link 
= Current.Link;
                Current.Link 
= NewNode;
            }

        }


        

        public Node FindPrevious(Object n)
        
{
            Node Current 
= Header;
            
while (!(Current.Link == null&& (Current.Link.Element != n))
            
{
                Current 
= Current.Link;
            }

            
return Current;
        }


        
//删除结点
        public void Remove(Object item)
        
{
            Node P 
= FindPrevious(item);
            
if (!(P.Link == null))
            
{
                P.Link 
= P.Link.Link;
            }

        }


        
//打印链表
        public void PrintList()
        
{
            Node Current 
= new Node();
            Current 
= this.Header;
            
while (Current.Link != null)
            
{
                Console.WriteLine(Current.Link.Element);
                Current 
= Current.Link;
            }

        }

        
    }


    
class Program
    
{
        
static void Main(string[] args)
        
{
            
//实例化结点
            Node FirstNode = new Node("Tommy");
            Node SecondNode 
= new Node("weiwei");
            Int32 Num 
= 5;
            
//因为我们定义结点的时候是用object类型,所以结点可以存储不同类型
            Node ThirdNode = new Node(Num);
            FirstNode.Link 
= SecondNode;
            SecondNode.Link 
= ThirdNode;
            ThirdNode.Link 
= null;
            LinkedList MyList 
= new LinkedList();
            
//将头结点指向第一个结点
            MyList.Header.Link = FirstNode;
            
//插入结点
            MyList.InsertNode("advantech""weiwei");
            MyList.InsertNode(
"插入链表""Tommy");
            
//打印链表中的结点元素
            MyList.PrintList();
            Console.ReadLine();
        }

    }

}
posted @ 2008-01-19 14:07  Tommy.wei  阅读(1899)  评论(20编辑  收藏  举报