Chinaunix首页 | 论坛 | 博客
  • 博客访问: 216471
  • 博文数量: 35
  • 博客积分: 1480
  • 博客等级: 上尉
  • 技术积分: 390
  • 用 户 组: 普通用户
  • 注册时间: 2007-11-14 14:27
文章分类

全部博文(35)

文章存档

2008年(35)

我的朋友

分类: C/C++

2008-03-16 20:55:57

/**设计一个算法,使用AvailSpace类,实现类似程序2-11的功能,建立一个采用模拟指针的单链表**/
#include
using namespace std;
template
struct Node
{
 Node(const T& e=T(),int next=0):element(e),link(next){}
    T element;
 int link;
    
};
template
class AvailSpace
{
public:
 AvailSpace(int maxSize=100);
 ~AvailSpace(){delete[] nodes;}
 int NewNode();
    void deleteNode(int i);
 friend void BuildList();
private:
 int numberofNodes;
 Node* nodes;
 int avail;
};
template
AvailSpace::AvailSpace(int maxSize)
{
numberofNodes=maxSize;
avail=0;
nodes=new Node[numberofNodes];
for(int i=0;inodes[numberofNodes-1].link=-1;
}
template
int AvailSpace::NewNode()
{
if(avail>-1)
{
int i=avail;
avail=nodes[avail].link;
return i;
}
else return -1;
}
template
void AvailSpace::deleteNode(int i)
{
nodes[i].link=avail;
avail=i;
i=-1;
}
void BuildList()
{
 int number;
 char c=0;
 int i;
 cout<<"please input the number of nodes"< cin>>number;
 static AvailSpace head=AvailSpace(number);
 cout<<"please input the nodes,* for end"< while(number>=0&&(c!='*'))
 {
  cin>>c;
  i=head.NewNode();
  if(i<0)
   cout<<"i="<  else
  {
  head.nodes[i].element=c;
  cout<<"nodes[i].element="<  }
        number--;
 }
}
void main()
{
BuildList();
}
阅读(1253) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~