前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >数据结构--线性表链式存储(链表)--单链表

数据结构--线性表链式存储(链表)--单链表

作者头像
风骨散人Chiam
发布2020-10-28 11:30:18
3970
发布2020-10-28 11:30:18
举报
文章被收录于专栏:CSDN旧文CSDN旧文

定义:

单链表是一种链式存取的数据结构,用一组地址任意的存储单元存放线性表中的数据元素。

链表中的数据是以节点来表示的,每个结点的构成:元素( 数据元素的映象) + 指针(指示后继元素存储位置),元素就是存储数据的存储单元,指针就是连接每个结点的地址数据。

链表特点:

根据线性表的长度动态的申请存储空间,以解决顺序存储中存在的存储空间难以确定的问题。

元素的要素:

  1. 指针:指向下一个元素。
  2. 值:当前元素储存的数据。
代码语言:javascript
复制
#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()
{
    //具体操作,不与给出
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-11-05 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档