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


    定义:

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

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

    链表特点:

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

    元素的要素:

    1. 指针:指向下一个元素。

    2. 值:当前元素储存的数据。

    #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()
    {
        //具体操作,不与给出
    }
    
  • 相关阅读:
    假设法求最大值和数组的优点
    要明白每个变量的语义,尽量避免一个变量有多重语义
    掷色子6000次分别统计出点子出现的次数
    c语言函数是怎么传递参数的
    为什么rand和srand总是同时出现?
    c语言解二元二次方程组
    【译】第三篇 Replication:事务复制-发布服务器
    【译】第二篇 Replication:分发服务器的作用
    【译】第一篇 Replication:复制简介
    【译】第八篇 Integration Services:高级工作流管理
  • 原文地址:https://www.cnblogs.com/lunatic-talent/p/12798615.html
Copyright © 2020-2023  润新知