数据结构--线性表链式存储(链表)--单链表
定义:
单链表是一种链式存取的数据结构,用一组地址任意的存储单元存放线性表中的数据元素。
链表中的数据是以节点来表示的,每个结点的构成:元素( 数据元素的映象) + 指针(指示后继元素存储位置),元素就是存储数据的存储单元,指针就是连接每个结点的地址数据。
链表特点:
根据线性表的长度动态的申请存储空间,以解决顺序存储中存在的存储空间难以确定的问题。
元素的要素:
-
指针:指向下一个元素。
-
值:当前元素储存的数据。
#include<bits/stdc++.h>
using namespace std;
template <typename T>
struct Node //节点类
{
T data;
Node<T> *next; //此处<T>也可以省略
};
template <class T>
class LinkList
{
Node<T> *first; // 单链表的头指针 , <T>可以省略
int length;
public:
LinkList ( )
{
first=new Node<T>;
first -> next= NULL ;
length=0;
}
LinkList ( T a[ ], int n ) ;
LinkList ( T a[ ], int n,int w) ;
~LinkList ( ) ;
int get_Len( )
{
return length;
};
T get_Loc ( int i ) ;
int ser_Loc ( T x ) ;
void ins_Loc ( int i, T x ) ;
T del_Loc ( int i ) ;
void print_List ( ) ;
};
template <class T>
LinkList<T>:: LinkList(T a[ ], int n)
{
first=new Node<T>; //生成头结点
first->next=NULL;
Node<T> *s;
for (int i=0; i<n; i++)
{
s=new Node<T>;
s->data=a[i]; //为每个数组元素建立一个结点
s->next=first->next;
first->next=s;
}
length=n;
}
template <class T>
LinkList<T>:: LinkList(T a[ ], int n,int w) //w并无实际意义,用于区分头插法于尾插法
{
Node<T> *r,*s; //尾指针
first=new Node<T>; //生成头结点
r=first;
for (int i=0; i<n; i++)
{
s=new Node<T>;
s->data=a[i]; //为每个数组元素建立一个结点
r->next=s;
r=s; //插入到终端结点之后
}
r->next=NULL; //单链表建立完毕,将终端结点的指针域置空
length=n;
}
template <class T>
void LinkList<T>:: print_List()
{
Node<T> *p;
p=first->next;
while(p)
{
cout<<p->data;
p=p->next;
}
}
template <class T>
T LinkList<T>::get_Loc(int i)
{
Node<T> *p;
int j;
p=first->next;
j=1; //或p=first; j=0;
for(int j=0;p && j<i-1;j++)
{
p=p->next; //工作指针p后移
j++;
}
if (!p)
throw "位置非法";
else
return p->data;
}
template <class T>
void LinkList<T>::ins_Loc(int i, T x)
{
Node<T> *p;
int j;
p=first ;
j=0; //工作指针p初始化
for(int j=0;p && j<i-1;j++)
{
p=p->next; //工作指针p后移
j++;
}
if (!p)
throw "位置非法";
else
{
Node<T> *s;
s=new Node<T>;
s->data=x; //向内存申请一个结点s,其数据域为x
s->next=p->next; //将结点s插入到结点p之后
p->next=s;
}
}
template <class T>
T LinkList<T>::del_Loc(int i)
{
Node<T> *p;
p=first ; //工作指针p初始化
for(int j=0;p && j<i-1;j++) //查找第i-1个结点
{
p=p->next;
j++;
}
if (!p || !p->next)
throw "位置非法"; //结点p不存在或结点p的后继结点不存在
else
{
Node<T> *q;
T x;
q=p->next;
x=q->data; //暂存被删结点
p->next=q->next; //摘链
delete q;
return x;
}
}
template <class T>
LinkList<T>:: ~LinkList()
{
Node<T> *q;
while (first)
{
q=first->next;
delete first;
first=q;
}
length=0;
}
int main()
{
//具体操作,不与给出
}