zoukankan      html  css  js  c++  java
  • [数据结构] 单链表

     数据结构的练习与巩固
    /////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
    1
    //结点定义 2 template <class T> 3 struct LinkNode 4 { 5 T data; //***可定义多个用来存储数据的变量 6 LinkNode<T>* link; 7 8 LinkNode(LinkNode<T>* ptr = NULL) 9 {link = ptr;} 10 LinkNode(const T& item, LinkNode<T> *ptr = NULL) 11 {data = item; link = ptr;} 12 };
      1 //单链表定义
      2 template <class T>
      3 class List: public LinearList<T>
      4 {
      5 protected:
      6     LinkNode<T>* first;         //链表首项
      7 
      8 public:
      9     List() 
     10          { first = new LinkNode<T>; }      //创建第一个结点,并将首项指针指向此结点
     11     List(const T& x)
     12          { first = new LinkNode<T>(x); }   //带有数值的构造函数
     13     List(List<T>& L);                      //复制构造函数
     14     ~List()                                //析构函数
     15          { makeEmpty(); }
     16     void makeEmpty();                      //删除链表
     17     int Length()const;                     //得到长度
     18 
     19     LinkNode<T>* getHead()const            //得到首项结点
     20          { return first; }
     21     LinkNode<T>* Search(T x);              //搜索数据为x的结点
     22     LinkNode<T>* Locate(int i);            //定位位置为i的结点
     23     bool getData(int i, T& x);             //得到位置为i的结点的数据
     24     bool Insert (int i, T& x);             //在位置i处插入数据为x的新结点
     25     bool Remove (int i, T& x);             //移除位置在i的结点,并获取该点数据
     26     bool IsEmpty()const                    //判断是否是空指针,只要知道首项指针的link是否为空即可
     27          {return first->link == NULL ? true : false;}
     28     bool IsFull()const                     //判断链表是否满,默认不会满
     29          {return false;}
     30     void Sort();                           //整理单链表
     31     void Input();                          //逐项创建单链表
     32     void Output();                         //逐项输出单链表
     33     List<T>& opertator = (List<T> & L);    //重构 = 
     34 }
     35 
     36 template <class T> 
     37 void List<T>::makeEmpty()
     38 {
     39     LinkNode<T>* q;
     40     while (first->link != NULL)
     41     {
     42         q = first->link;         //从头开始逐项删除
     43         first->link = q->link;
     44         delete p;
     45     }
     46 }
     47 
     48 template <class T>
     49 int List<T>::Length()const
     50 {
     51     LinkNode<T>* p = first->link; //从头开始计数
     52     int count = 0;
     53     while (p != NULL)             //当该节点为非空结点时
     54     {
     55         count++;
     56         p = p->link;              //p指向下一位
     57     }
     58     return count;
     59 }
     60 
     61 template <class T>
     62 LinkNode<T>* List<T>::Search(T x)
     63 {
     64     LinkNode<T>* p = first->link;  //从头开始找 所要找的结点
     65     while (p != NULL)              //当结点非空的时候
     66         if (p->data == x)break;    //当结点数据与所查找数据一致时
     67         else p = p->link;          //如果不一致,则移至下一位
     68     return p;                      //当到结尾依旧没找到时,会指向空结点(最后一位是空结点)
     69 }
     70 
     71 template <class T>
     72 LinkNode<T>* List<T>::Locate(int i)
     73 {
     74     if (i < 0)return NULL;
     75     LinkNode<T>* p = first;        //从头开始数
     76     int j = 0;                     //创建一个用于计数的变量
     77     while (p != NULL && j < i)     //当没有到结尾的时候,继续向后移动
     78     {
     79         p = p->link;
     80         j++;
     81     }
     82     return p;                      //当到结尾依旧没找到时,会指向空结点(最后一位是空结点)
     83 }
     84 
     85 template <class T>
     86 bool List<T>::getData()
     87 {
     88     if (i <= 0)return NULL;         //如果输入的位置不符合规范,则返回0值
     89     LinkNode<T>* p = Locate(i);     //定位i处
     90     if (p == NULL)                  //如果该处是空结点,则返回0值
     91         { return false; }
     92     else 
     93         { x = p->data; return true; }
     94 }
     95 
     96 template <class T>
     97 bool List<T>::Insert(int i, T&x)
     98 {
     99     LinkNode<T>* p = Locate(i);
    100     if (p == NULL)return false;
    101     else 
    102     {
    103         New = new LinkNode<T>(x);
    104         if (New == NULL) 
    105              { cerr << "错误:申请了空结点" << endl; exit(1); }
    106         New->link = p->link;      //插入新结点,前后关系变化
    107         p->link = New;
    108         return true;
    109     }
    110 }
    111 
    112 template <class T>
    113 bool List<T>::Remove(int i, T&x)
    114 {
    115     LinkNode<T>* p = Locate(i - 1);    //定位所删节点的前一位
    116     if (p == NULL || p->link == NULL)  //如果此处或此处后一位,为空结点
    117         return false;
    118     LinkNode<T>* q = p->link;          //令q指向所删节点
    119     x = q->data;                       //提取所删节点数据
    120     p->link = q->link;                 //前后关系变化
    121     delete q;                          //删除该节点
    122     return true;
    123 }
    124 
    125 template <class T>
    126 List<T>& List<T>::Operator = (List<T> & L)
    127 {
    128     T value;
    129     LinkNode<T>* srcptr = L.getHead();     //令源头指针指向源链表头部
    130     LinkNode<T>* destptr = first = new LinkNode<T>;  //创建新结点(新单链表)并让首相指针指向该结点
    131     while (srcptr->link != NULL)           //当源指针 仍未指向 源链表 的结尾空指针时
    132     {
    133         value = srcptr->link->data;        //令value=该结点的值
    134         destptr->link = new LinkNode<T>(value); //创建新结点并将value赋予
    135         destptr = destptr->link;           //向后移一位
    136         srcptr = strpt->link;              //向后移一位
    137     }
    138     destptr->link = NULL;                  //结尾指针指向空
    139     return *this;                          //返回这个复制链表
    140 }
    141 
    142 //补充函数
    143 template <class T>
    144 void List<T>::inputFront(T endTag)    //前插法建立单链表
    145 {
    146     LinkNode<T>* newNode;                 //创建新结点
    147     T value;                              
    148     makeEmpty();                          //置空单链表
    149     cin >> value;
    150     while (value != endTag)               //当没有输入停止符时
    151     {
    152         newNode = new LinkNode<T>(value); //创建新结点
    153         if (newNode == NULL)              //当创建了空结点时
    154         {
    155             cerr << "error" << endl; exit(1);
    156         }
    157         newNode->link = first->link;      //前后关系变化
    158         first->link = newNode;
    159         cin >> value;                     //输入新value
    160     }
    161 }
    162 
    163 template <class T>
    164 void List<T>::inputRear(T endTag)    //后插法建立单链表
    165 {
    166     LinkNode<T>* newNode, * last;
    167     T value; 
    168     makeEmpty();
    169     cin >> value;
    170     last = first;
    171     while (value != endTag)               //当没有输入停止符时
    172     {
    173         newNode = new LinkNode<T>(value); //创建新结点
    174         if(newNode==NULL)                 //当创建了空结点时
    175         {
    176             cerr << "error" << endl; exit(1);
    177         }
    178         last->link = newNode;             //前后关系变化
    179         last = newNode;
    180         cin >> value;                     //输入新value
    181     }
    182 }
  • 相关阅读:
    sqlserver 中的 substring函数(转)
    C#二个相减怎么获得天数,就是比如201225 与201231之间相差的天数
    C++文件添加到项目中
    VS2008动态链接库(DLL)的创建与导入
    美剧字幕绿箭侠第1季第7集
    C++中#define用法
    C++头文件的重复引用
    visual studio中解决方案是什么
    NewWords/300400
    指针
  • 原文地址:https://www.cnblogs.com/nagishiro/p/13137687.html
Copyright © 2011-2022 走看看