C++实现静态链表

 更新时间:2020年07月27日 11:50:32   作者:ChanJose  
这篇文章主要为大家详细介绍了C++实现静态链表,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C++实现静态链表的具体代码,供大家参考,具体内容如下

一、动态链表和静态链表区别:

(1)动态链表:

(2)静态链表:       应用:二叉树

二、思路:

1.结点设置:T data;

                     int link;

2.链表要用一个avil来保存可分配空间的首地址;

3.初始化:引入头结点:elem[0];

                  头结点先指向空NULL, 用-1表示;

                  avil存储空分配的空间的首地址1;

                  然后让其它可分配空间的结点的link指向坐标大一的结点;

三、实现程序:

#ifndef StaticList_h
#define StaticList_h
const int maxSize = 100; // 静态链表大小
template <class T>
struct SLinkNode {
 T data; // 结点数据
 int link; // 结点链接指针
};
 
template <class T>
class StaticList {
public:
 void InitList(); // 初始化
 int Length(); // 计算静态链表的长度
 int Search(T x); // 在静态链表中查找具有给定值的结点
 int Locate(int i); // 在静态链表中查找第i个结点
 bool Append(T x); // 在静态链表的表尾追加一个新结点
 bool Insert(int i, T x); // 在静态链表第i个结点后插入新结点
 bool Remove(int i); // 在静态链表中释放第i个结点
 bool isEmpty(); // 判链表空否?
private:
 SLinkNode<T> elem[maxSize];
 int avil; // 当前可分配空间首地址
};
 
template <class T>
void StaticList<T>::InitList() {
 // 初始化
 elem[0].link = -1;
 avil = 1;
 // 当前可分配空间从1开始建立带表头结点的空链表
 for(int i = 1; i < maxSize - 1; i++)
 elem[i].link = i + 1; // 构成空闲链接表
 elem[maxSize-1].link = -1;
}
 
template <class T>
int StaticList<T>::Length() {
 // 计算静态链表的长度
 int p = elem[0].link;
 int i = 0;
 
 while(p != -1) {
 p = elem[p].link;
 i++;
 }
 return i;
}
 
template <class T>
int StaticList<T>::Search(T x) {
 // 在静态链表中查找具有给定值的结点
 int p = elem[0].link; // 指针p指向链表第一个结点
 
 while(p != -1) { // 逐个结点检测查找给定的值
 if(elem[p].data == x)
 break;
 else
 p = elem[p].link;
 }
 return p;
}
 
template <class T>
int StaticList<T>::Locate(int i) {
 // 在静态链表中查找第i个结点
 if(i < 0) // 参数不合理
 return -1;
 if(i == 0)
 return 0;
 int j = 1, p = elem[0].link;
 while(p != -1 && j < i) { // 循链查找第i号结点
 p = elem[p].link;
 j++;
 }
 return p;
}
 
template <class T>
bool StaticList<T>::Append(T x) {
 // 在静态链表的表尾追加一个新结点
 if(avil == -1) // 没有分配到存储空间
 return false;
 int q = avil; // 分配结点
 avil = elem[avil].link; // 指向下一个可分配的结点
 elem[q].data = x;
 elem[q].link = -1;
 int p = 0;
 // 查找表尾
 while(elem[p].link != -1)
 p = elem[p].link;
 elem[p].link = q; // 追加
 return true;
}
 
template <class T>
bool StaticList<T>::Insert(int i, T x) {
 // 在静态链表第i个结点后插入新结点
 int p = Locate(i);
 
 if(p == -1) // 找不到结点
 return false;
 int q = avil; // 分配结点
 avil = elem[avil].link;
 elem[q].data = x;
 elem[q].link = elem[p].link; // 链入
 elem[p].link = q;
 return true;
}
 
template <class T>
bool StaticList<T>::Remove(int i) {
 // 在静态链表中释放第i个结点
 int p = Locate(i-1);
 
 if(p == -1) // 找不到结点
 return false;
 int q = elem[p].link; // 第i号结点
 elem[p].link = elem[q].link;
 elem[q].link = avil; // 释放,让q的link指向原可分配的结点
 avil = q; // avil指向q
 return true;
}
 
template <class T>
bool StaticList<T>::isEmpty() {
 // 判链表空否?
 if(elem[0].link == -1)
 return true;
 return false;
}
 
#endif /* StaticList_h */

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C++ 强制类型转换详解

    C++ 强制类型转换详解

    这篇文章主要介绍的是C++ 强制类型转换详解,C语言中的强制转换主要用于普通数据类型、指针的强制转换,没有类型检查,转换不安全,下面我们来看看其具体语法及详细内容
    2021-11-11
  • C语言中的指针 初阶

    C语言中的指针 初阶

    这篇文章主要介绍的是关于初级阶段学习C语言中指针的一些内容,那就是指针是什么?简单的说,就是通过它能找到以它为地址的内存单元。下面文章我们就来详细介绍该内容,需要的朋友可以参考一下
    2021-10-10
  • C语言中输入函数(scanf()、fgets()和gets())的区别详解

    C语言中输入函数(scanf()、fgets()和gets())的区别详解

    这篇文章主要给大家介绍了关于C语言中三种输入函数(scanf()、fgets()和gets())区别的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧。
    2017-11-11
  • C++中关于this指针的入门介绍

    C++中关于this指针的入门介绍

    this 指针在C++类和对象中是个很方便实用的关键字,可以简化对象成员属性的调用,使代码表达的含义更加准确;在之前的学习中我们都可以判断变量所占内存空间大小,那么我们创建的类对象所占的内存空间怎么计算呢?想知道this的妙用和类对象占用的内存空间就来跟我学习吧
    2022-07-07
  • C语言的分支和循环语句你了解吗

    C语言的分支和循环语句你了解吗

    这篇文章主要为大家详细介绍了C语言的分支和循环语句,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • 浅理解C++ 人脸识别系统的实现

    浅理解C++ 人脸识别系统的实现

    这篇文章主要介绍了浅理解C++ 人脸识别系统的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-03-03
  • opencv3/C++轮廓的提取与筛选方式

    opencv3/C++轮廓的提取与筛选方式

    今天小编就为大家分享一篇opencv3/C++轮廓的提取与筛选方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-12-12
  • C++使用tinyxml库处理XML文件

    C++使用tinyxml库处理XML文件

    TinyXML是一个开源的解析XML的解析库,能够用于C++,能够在Windows或Linux中编译,这个解析库的模型通过解析XML文件,然后在内存中生成DOM模型,从而让我们很方便的遍历这棵XML树,本文为大家介绍的是使用tinyxml库处理XML文件,需要的可以参考一下
    2023-07-07
  • C++中sort()函数和priority_queue容器中比较函数的区别详析

    C++中sort()函数和priority_queue容器中比较函数的区别详析

    C++中sort()和priority_queue都能自定义比较函数,其中sort()自定义的比较函数比较好理解,priority_queue中自定义的比较函数的效果和sort()是相反的,这篇文章主要给大家介绍了关于C++中sort()函数和priority_queue容器中比较函数的区别的相关资料,需要的朋友可以参考下
    2023-03-03
  • C++非递归建立二叉树实例

    C++非递归建立二叉树实例

    这篇文章主要介绍了C++非递归建立二叉树的方法,实例分析了二叉树的原理与C++实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-04-04

最新评论