静态链表是使用数组实现的能够高速插入和删除数据的链表,静态链表和链式单链表比的缺点在于链表的长度仅仅能初始化设置好,而相相应普通的顺序存储的链表,静态链表不能实现高速的读写随意的元素。

当然静态链表给了我们一种思考方式,当我们在特定状态下,不能使用指针操作时。我们能够使用一种替代指针的方法,静态链表使用的cur来表示当前节点的下一个节点的下标。

#pragma once
#define MAXSIZE 1000 template<typename EleType>
class StaticList
{
public:
typedef struct
{
EleType data;
int cur;
}Node;
StaticList();
~StaticList();
bool Insert(const EleType& e, int index = 1);
bool Delete( EleType& e, int index = 1);
void Show()const;
private:
int NewSpace();//返回list中一个能够用的空间下标
void DeleteSpace(int index);//删除list中的index元素
bool Empty()const;
bool Full()const;
Node StList[MAXSIZE];
int Length;
};
#include "StaticList.h"
#include<iostream>
using namespace std; template<typename EleType>
StaticList<EleType>::StaticList() :Length(0)
{
for (int i = 0; i < MAXSIZE - 1;++i)
{
StList[i].cur = i + 1;
}
StList[MAXSIZE - 1].cur = 0; } template<typename EleType>
StaticList<EleType>::~StaticList()
{ } template<typename EleType>
bool StaticList<EleType>::Insert(const EleType& e, int index /*= 1*/)
{
if (Full())//假设为满,则不插入数据
{
cout << "Can't insert element to a full List!\n";
return false;
}
if (index<1||index>Length+1)//假设插入点的下标不合法,返回false
{
cout << "The invalid index!\n";
return false;
}
int k = NewSpace();//返回一个能够插入的节点的下标
int j = MAXSIZE - 1;
if (k)//假设返回下标不为0
{
StList[k].data = e;//将返回位置的数据设置成e
for (int i = 1; i <= index - 1;++i)//找到插入节点的前一个节点的下标
{
j = StList[j].cur;
}
StList[k].cur = StList[j].cur;//将插入节点的cur设置成插入位置前一个节点的cur
StList[j].cur = k;//将插入位置的前一个节点的cur设置成k,实现把第k个节点插入到index-1个节点后。实现把第K个节点插入到第index个位置
++Length;//链表长度加一
return true;
} return false;
} template<typename EleType>
bool StaticList<EleType>::Delete(EleType& e, int index /*= 1*/)
{
if (Empty())//假设链表为空。不运行删除操作
{
cout << "Can't delete element in a empty list!\n";
return false;
}
if (index<1 || index>Length )//假设删除的位置不合法,返回false
{
cout << "The invalid index!\n";
return false;
}
int k = MAXSIZE - 1;
int i = 1;
for (; i <= index - 1;++i)//找到第index-1个节点k
{
k = StList[k].cur;
}
i = StList[k].cur;//i为第index个节点的下标
StList[k].cur = StList[i].cur;//将第index-1个节点的cur设置成第index个节点的cur,实现了把第index个节点排除在链表之外
e = StList[i].data;//返回第index个节点的data给e
DeleteSpace(i);//回收第index个节点的空间
--Length;//链表长度减一
return true;
} template<typename EleType>
void StaticList<EleType>::Show() const
{
if (Empty())
{
cout << "The List is Empty!\n";
return;
}
int k = StList[MAXSIZE - 1].cur;
cout << "The list is :\n";
for (int i = 1; i <= Length;++i)
{
cout << StList[k].data << " ";
k = StList[k].cur;
}
cout << endl;
} template<typename EleType>
bool StaticList<EleType>::Full() const
{
if (Length > MAXSIZE - 2)//保证StList[0]和StList[MAXSIZE-1]不被插入数据覆盖
{
return true;
}
return false;
} template<typename EleType>
bool StaticList<EleType>::Empty() const
{
return(Length == 0);
} template<typename EleType>
void StaticList<EleType>::DeleteSpace(int index)
{
StList[index].cur = StList[0].cur;//将要删除的节点增加到空暇节点最前
StList[0].cur = index;//把该节点设置成第一个可用的空暇节点
} template<typename EleType>
int StaticList<EleType>::NewSpace()
{
int i = StList[0].cur;//第一个可用的空暇姐弟那 if (StList[0].cur)//假设该空暇节点可用
{
StList[0].cur = StList[i].cur;//设置下一次第一个可用的空暇节点为返回节点的下一个节点
}
return i;//返回可用节点的下标
}
#include "StaticList.cpp"

int main()
{
StaticList<int> TestList;
TestList.Insert(12);
TestList.Insert(12);
TestList.Insert(34); TestList.Insert(23);
TestList.Insert(12); TestList.Insert(99,4);
TestList.Show();
int m = 0;
TestList.Delete(m,7);
cout << "____________" << m << "_______________\n";
TestList.Show();
return 0;
}

静态链表的C++实现的更多相关文章

  1. 使用C语言描述静态链表和动态链表

    静态链表和动态链表是线性表链式存储结构的两种不同的表示方式. 静态链表的初始长度一般是固定的,在做插入和删除操作时不需要移动元素,仅需修改指针,故仍具有链式存储结构的主要优点. 动态链表是相对于静态链 ...

  2. 静态链表 C语言描述

    静态链表1.下标为0的游标存放最后存放数据节点的游标,即是第一个没有存放元素(备用链表)的下标2.最后一个的节点存放第一个由数值得下标3.第一个和最后一个都不存放数据 即是备用链表的第一个的下标 4. ...

  3. 03静态链表_StaticLinkList--(线性表)

    #include "string.h" #include "ctype.h" #include "stdio.h" #include &qu ...

  4. java与数据结构(2)---java实现静态链表

    结点类 1 //结点类 2 class Node<T> { 3 private T data; 4 private int cursor; 5 6 Node(T data, int cur ...

  5. 静态链表实现 (A-B)U(B-A)

    图中黄色部分为(A-B)U(B-A)的实际意义,用结构数组做静态链表来实现该表达式 大致流程是先建立A链表,接着将挨个输入的B中元素在A链表中遍历.如果没找到,就加到A链表结尾下标为endpointe ...

  6. C链表之创建简单静态链表

    C代码: #include<stdio.h> #include<stdlib.h> #include<malloc.h> //创建简单静态链表 typedef st ...

  7. 静态链表实现(A-B)+(B-A)【代码】

    -----------------------------------------------第一次发代码,写在前面------------------------------------------ ...

  8. 静态链表C语言数据结构

    静态链表就是将数组实现单链表: int Malloc_SLL(StaticLinkList space) { int i = space[0].cur;//取得第一个头节点的下标 if( space[ ...

  9. 静态链表的C实现(基于数据结构 严蔚敏)

    静态链表是利用一维数组实现逻辑上的单链表结构,结点的逻辑上相邻但物理位置上不一定相邻,因为内存分配上是一次性的,故称为静态. 特点: 预先需要一片连续的存储空间: 非随机存取: 无现成的"内 ...

  10. c++ 简单静态链表

    所有结点(结构体变量)都是在程序中定义的,不是临时开辟的,也不能用完后释放,这种链表称为静态链表.对各结点既可以通过上一个结点的next指针去访问,也可以直接通过结构体变量名s1, s2, s3去访问 ...

随机推荐

  1. (转)Spring中的事务操作

    http://blog.csdn.net/yerenyuan_pku/article/details/70024364 事务的回顾 什么是事务 事务是逻辑上的一组操作,组成这组操作的各个逻辑单元,要么 ...

  2. bdflush - 将dirty缓存写回到磁盘的核心守护进程

    总览(SYNOPSIS) bdflush [opt] 描述(DESCRIPTION) bdflush 被用来启动核心守护进程将内存中的dirty缓存写到磁盘上.真正清洁工作是一个核心程序完成的. bd ...

  3. spring的设计思想

    在学习Spring框架的时候, 第一件事情就是分析Spring的设计思想 在学习Spring的时候, 需要先了解耦合和解耦的概念 耦合: 简单来说, 在软件工程当中, 耦合是指对象之间的相互依赖 耦合 ...

  4. day02 python函数基础

    '''''''''列表: 定义: 在[]内,可以存放多个任意类型的值, 并以逗号隔开. 一般用于存放学生的爱好,课堂的周期等等...'''# 定义一个学生列表,可存放多个学生# list(['钱垚', ...

  5. SQL Server中 sysobjects、sysolumns、systypes

    1.sysobjects    系统对象表. 保存当前数据库的对象,如约束.默认值.日志.规则.存储过程等 在大多数情况下,对你最有用的两个列是Sysobjects.name和Sysobjects.x ...

  6. ORA-28000: the account is locked-详细解决方案

    运行-->cmd-->sqlplus /nolog conn system/orcl(或预设的密码) alter user scott identified by tiger(或预设密码) ...

  7. 笔试算法题(43):布隆过滤器(Bloom Filter)

    议题:布隆过滤器(Bloom Filter) 分析: BF由一个很长的二进制向量和一系列随机映射的函数组成,通过多个Hash函数将一个元素映射到一个Bit Array中的多个点,查询的时候仅当所有的映 ...

  8. mysql explain的使用

    一.explain返回各列的含义: 1.table:显示这一行的数据是关于那张表的 2.type:重要的列,显示连接使用了何种类型,从最好到最差的连接类型为const.eq_reg.ref.range ...

  9. drupal8 用户指南

    一句话概括 - 官方文档 概念- Drupal是个内容管理系统哦 那么,什么是内容管理系统? 就是用户自己编辑自己的网站内容的一个系统. 那么,什么是Drupal呢? Drupal是一个通过模块和主题 ...

  10. 修改Python的镜像源

    Mac OS下修改Python的镜像源 步骤: 切换到家目录 创建目录 .pip 并切换到该目录 创建 pip.conf 文件并写入配置信息 [global] index-url = https:// ...