【发布时间】:2011-08-05 14:32:11
【问题描述】:
我正在阅读一个教程,我也查看了整个谷歌,但我找不到关于链接列表如何工作的详细信息的很好解释......我对结构/格式感到非常困惑,我真的希望链接list 对我来说很有意义,因为它们听起来很棒,是一个可调整大小和可修改的数组...如果您需要查看我在说什么,下面是我从 tut 获得的一些代码。我对追加方法或删除等方法感到困惑,它们的作用以及列表中的尾头是如何工作的......这本书只是从一个例子开始,没有给出解释......
请帮助解决这个困惑..
class ListEntry
{
int data;
ListEntry next;
public ListEntry( int d )
{
data = d;
next = null;
}
public int Data
{
get{ return data; }
set{ data = value; }
}
public ListEntry Next
{
get{ return next; }
set{ next = value; }
}
public override string ToString( )
{
return( data.ToString( ) );
}
}
class TestProgram
{
static void Main( )
{
List list = new List( );
list.Append( 3);
Console.WriteLine( list );
list.Append( 1 );
Console.WriteLine( list );
list.Append( 6 );
Console.WriteLine( list );
list.Prepend( 4 );
Console.WriteLine( list );
// continued…
// Continued…
list.Prepend( 5 );
Console.WriteLine( list );
list.DeleteFirst( 4 );
Console.WriteLine( list );
list.Prepend( 2 );
Console.WriteLine( list );
Console.WriteLine( "Head data = " + list.Head );
Console.WriteLine( "Tail data = " + list.Tail );
list.Clear( );
Console.WriteLine( list );
Console.WriteLine( "IsEmpty = " + list.IsEmpty );
}
}
using System;
class List
{
ListEntry head;
ListEntry tail;
class ListEntry
{
// Put declaration of ListEntry here. Nesting of the classes is valid. In fact, class nesting is
// preferable if one class is only used within the context of another class.
}
public List( )
{
head = null;
tail = null;
}
// Continued…
public int Head
{
get{ return head.Data; }
}
public int Tail
{
get{ return tail.Data; }
}
public bool IsEmpty
{
get{ return( head == null ); }
}
public override string ToString( )
{
string tmp = "";
ListEntry current = head;
if( current == null )
{
tmp = "Empty";
}
while( current != null )
{
tmp += current + " ";
current = current.Next;
}
return( tmp );
}
public void Append( int i )
{
ListEntry tmp = new ListEntry( i );
tmp.Next = null;
if( head == null )
{
head = tmp;
}
else
{
tail.Next = tmp;
}
tail = tmp;
}
public void Prepend( int i )
{
ListEntry tmp = new ListEntry( i );
tmp.Next = head;
if( head == null )
{
tail = tmp;
}
head = tmp;
}
public void DeleteFirst( int i )
{
ListEntry current = head;
ListEntry previous = null;
while( current != null && current.Data != i )
{
previous = current;
current = current.Next;
}
if( current == null )
{
throw new ArgumentException( "List entry not found" );
}
// Continued…
// Continued…
if( current == head )
{
head = current.Next;
}
else
{
previous.Next = current.Next;
}
if( current == tail )
{
tail = previous;
}
}
还有其他方法,例如: 一个 Sort( ) 方法 FindFirst() 方法 FindNext() 方法 一个 InsertBefore() 方法 一个 InsertAfter( ) 方法
但现在基本的都很好..
【问题讨论】:
-
这是作业吗?如果是这样,请标记它。
-
查看这篇文章:[stackoverflow.com/questions/169973/…希望这可以为您解决问题。 [1]:stackoverflow.com/questions/169973/…
-
这不是我试图学习 C# 的家庭作业,教程提供了这个例子,我直接从 tut..
标签: c# data-structures linked-list