C++通过类实现线性表

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

下图是标准C语言实现的函数定义

下面可以用C++实现,第一个参数就是this的指针

list.h函数

#pragma once
typedef int Elem;
class List
{
public:
 List(int size);
 ~List();
 void ClearList();                  // 将数组长度设为0
 bool ListEmpty();                  // 判断数组是否为空
 int ListLength();                  // 获取数组长度
 bool GetElem(int i, Elem *e);            // 查找指定下标元素
 int LocateElem(Elem *e);              // 查找指定元素
 bool PriorElem(Elem *currentElem, Elem *preElem);  // 查找元素的前驱元素
 bool NextElem(Elem *currentElem, Elem *nextElem);  // 查找元素的后继元素
 void ListTraverse();                // 遍历线性表,输出元素
 bool ListInsert(int i, Elem *e);          // 在指定位置插入一个元素
 bool ListDelete(int i, Elem *e);          // 删除指定位置元素
private:
 int *m_pList;                    // 指向一块内存
 int m_iSize;                    // 内存的大小
 int m_iLength;                   // 数组的长度
};

类的实现,list.cpp

#include<iostream>
#include "List.h"
using namespace std;

List::List(int size)
{
 m_iSize = size;
 m_pList = new Elem[m_iSize];
 m_iLength = 0;
}

List::~List()
{
 delete[] m_pList; // 释放数组内存
 m_pList = NULL;
}

void List::ClearList()
{
 m_iLength = 0;
}

bool List::ListEmpty()
{
 return m_iLength == 0 ? true : false;
}

int List::ListLength()
{
 return m_iLength;
}

bool List::GetElem(int i, Elem *e)
{
 if (i < 0 || i >= m_iSize)
 {
 return false;
 }
 *e = m_pList[i];
 return true;
}

int List::LocateElem(Elem *e)
{
 for (int i = 0; i < m_iLength; i++)
 {
 if (m_pList[i] == *e)
 {
  return i;
 }
 }
 return -1;
}

bool List::PriorElem(Elem *currentElem, Elem *preElem)
{
 int temp = LocateElem(currentElem); // 查找元素的序号
 if (temp == -1)
 return false;
 else if (temp == 0)
 return false;
 else
 {
 *preElem = m_pList[temp - 1];
 return true;
 }

}

bool List::NextElem(Elem *currentElem, Elem *nextElem)
{
 int temp = LocateElem(currentElem); // 查找元素的序号
 if (temp == -1)
 return false;
 else if (temp == m_iLength - 1)
 return false;
 else
 {
 *nextElem = m_pList[temp + 1];
 return true;
 }
}

void List::ListTraverse()
{
 for (int i = 0; i < m_iLength; i++)
 {
 cout << m_pList[i] << endl;
 }
}

bool List::ListInsert(int i, Elem *e)
{
 if (i<0 || i>m_iLength)
 return false;
 for (int k=m_iLength-1;k>=i;k--)
 {
 m_pList[k + 1] = m_pList[k];
 }
 m_pList[i] = *e;
 m_iLength++;
 return true;
}

bool List::ListDelete(int i, Elem *e)
{
 if (i<0 || i>m_iLength)
 return false;
 *e = m_pList[i];
 for (int k = i + 1; k < m_iLength; k++)
 {
 m_pList[k - 1] = m_pList[k];
 }
 m_iLength--;
 return true;
}

测试主程序

#include<iostream>
#include "List.h"
using namespace std;

int main()
{
 Elem temp;
 Elem arry[11] = { 3,5,7,2,9,1,8 };
 List *list1 = new List(10);
 cout << "length:" << list1->ListLength() << endl;
 for (int i = 0; i < 7; i++)
 {
 list1->ListInsert(i, &arry[i]);
 }
 cout << "length:" << list1->ListLength() << endl;
 // 删除第一个元素
 list1->ListDelete(0, &temp);
 cout << temp << endl;
 // 搜索前驱元素
 list1->PriorElem(&arry[4], &temp);
 cout << temp << endl;
 list1->NextElem(&arry[4], &temp);
 cout << temp << endl;
 list1->ListTraverse();
 delete list1;
  return 0;
}

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

(0)

相关推荐

  • 解析C++的线性表链式存储设计与相关的API实现

    基本概念 链式存储定义: 为了表示每个数据元素与其直接后继元素之间的逻辑关系,每个元素除了存储本身的信息外,还需要存储指示其直接后继的信息. 表头结点: 链表中的第一个结点,包含指向第一个数据元素的指针以及链表自身的一些信息. 数据结点: 链表中代表数据元素的结点,包含指向下一个数据元素的指针和数据元素的信息. 尾结点: 链表中的最后一个数据结点,其下一元素指针为空,表示无后继. 链表技术领域推演 链表链式存储_api实现分析: 在C语言中可以用结构体来定义链表中的指针域,链表中的表头结点也可以

  • C++ 数据结构线性表-数组实现

    C++ 数据结构线性表-数组实现 线性表的数组实现,实现几个核心的功能,语言是C++,如果有更好的想法和意见,欢迎留言~~~ /* Author : Moyiii * 线性表的数组实现,仅作学习之用,当然如果 * 你想拿去用,随你好啦. */ #include<iostream> using namespace std; //顺序表 class SeqList { public: //构造函数,接受一个默认的列表大小 SeqList(int size = MAX_LIST_SIZE); //析

  • C++实现动态线性表

    之前在学习c语言的时候用c语言实现了动态线性表.现在再使用c++实现一下动态线性表. 相关数据结构方面就不多说了.在之前的博客里也有.下面就直接来实现吧. 这里使用指针来遍历数组,这样在算size,capacity的时候,直接用指针相减的方式就可以得到元素个数,以及容量. Vector.h #include <iostream> #include<assert.h> #include<stdio.h> #include<string.h> //用typede

  • C++语言实现线性表之链表实例

    本文实例讲述了C++语言实现线性表之链表实现方法.分享给大家供大家参考.具体分析如下: 插入.删除结点的代码有点多,但这样提高了代码的可读性,且不增加时间复杂度,不会影响程序性能 #include <iostream> using namespace std; template<typename T> class CList; template<class T> class Node { friend CList<T>; private: T m_data;

  • C++语言实现线性表之数组实例

    本文实例讲述了C++语言实现线性表之数组.分享给大家供大家参考.具体分析如下: 感觉用C++中的构造函数.析构函数等类的特点来描述一些数据结构更加易读,更加合理,便捷.但有一个问题,编译器不支持模板的分离编译,很不舒服 #include <iostream> using namespace std; template<class T> class CArray { public: CArray(const int &iMax); CArray(); ~CArray(); v

  • C++通过类实现线性表

    本文实例为大家分享了C++类实现线性表的具体代码,供大家参考,具体内容如下 下图是标准C语言实现的函数定义 下面可以用C++实现,第一个参数就是this的指针 list.h函数 #pragma once typedef int Elem; class List { public: List(int size); ~List(); void ClearList(); // 将数组长度设为0 bool ListEmpty(); // 判断数组是否为空 int ListLength(); // 获取数

  • java线性表的存储结构及其代码实现

    Java数据结构学习笔记第一篇: 用程序后在那个的数据大致有四种基本的逻辑结构: 集合:数据元素之间只有"同属于一个集合"的关系 线性结构:数据元素之间存在一个对一个的关系 树形结构:数据元素之间存在一个对多个关系 图形结构或网状结构:数据元素之间存在多个对多个的关系 对于数据不同的逻辑结构,计算机在物理磁盘上通常有两种屋里存储结构 顺序存储结构 链式存储结构 本篇博文主要讲的是线性结构,而线性结构主要是线性表,非线性结构主要是树和图. 线性表的基本特征: 总存在唯一的第一个数据元素

  • java 线性表接口的实例详解

    java 线性表接口的实例详解 前言: 线性表是其组成元素间具有线性关系的一种线性结构,对线性表的基本操作主要有插入.删除.查找.替换等,这些操作可以在线性表的任何位置进行.线性表可以采用顺序存储结构和链式存储结构表示. 本接口的类属于dataStructure包的linearList子包.线性表接口LList声明如下,描述线性表的取值.置值.插入.删除等基本操作. package dataStructure.linearList; public interface LList<E> { bo

  • C#实现顺序表(线性表)完整实例

    本文实例讲述了C#实现顺序表(线性表)的方法.分享给大家供大家参考,具体如下: 基本思想是使用数组作为盛放元素的容器,数组一开始的大小要实现确定,并使用一个Pointer指向顺序表中最后的元素.顺序表中的元素是数组中元素的子集.顺序表在内存中是连续的,优势是查找,弱势是插入元素和删除元素. 为避免装箱拆箱,这里使用泛型,代替object.使用object的例子可以参照本站这篇文章:http://www.jb51.net/article/87603.htm,这个链接中的例子实现的是队列,并没 有使

  • 简单介绍线性表以及如何实现双链表

    线性表是一种线性结构,它是具有相同类型的n(n≥0)个数据元素组成的有限序列. 一.数组 数组有上界和下界,数组的元素在上下界内是连续的. 存储10,20,30,40,50的数组的示意图如下: 数组的特点:数据是连续的:随机访问速度快. 数组中稍微复杂一点的是多维数组和动态数组.对于C语言而言,多维数组本质上也是通过一维数组实现的.至于动态数组,是指数组的容量能动态增长的数组:对于C语言而言,若要提供动态数组,需要手动实现:而对于C++而言,STL提供了Vector:对于Java而言,Colle

  • JS实现线性表的链式表示方法示例【经典数据结构】

    本文实例讲述了JS实现线性表的链式表示方法.分享给大家供大家参考,具体如下: 从上一节可以,顺序存储结构的弱点就是在插入或删除操作时,需要移动大量元素.所以这里需要介绍一下链式存储结构,由于它不要求逻辑上相邻的元素在物理位置上也相邻,所以它没有顺序存储结构的弱点,但是也没有顺序表可随机存取的优点. 下面介绍一下什么是链表. 线性表的链式存储结构用一组任意的存储单元存储线性表的数据元素.所以,每一个数据元素除了存储自身的信息之外,还需要存储一个指向其后继的存储位置的信息.这两部分信息组成了元素的存

  • 顺序线性表的代码实现方法

    1.采用一个数组实现一个顺序线性表中添加元素.删除元素等基本操作 package com.ietree.basic.datastructure.Sequence; import java.util.Arrays; /** * 顺序线性表 * * @param <T> * @author Dylan */ public class SequenceList<T> { private final int DEFAULT_SIZE = 16; // 保存数组的长度 private int

  • C#实现单链表(线性表)完整实例

    本文实例讲述了C#实现单链表(线性表)的方法.分享给大家供大家参考,具体如下: 顺序表由连续内存构成,链表则不同.顺序表的优势在于查找,链表的优势在于插入元素等操作.顺序表的例子:http://www.jb51.net/article/87605.htm 要注意的是,单链表的Add()方法最好不要频繁调用,尤其是链表长度较长的时候,因为每次Add,都会从头节点到尾节点进行遍历,这个缺点的优化方法是将节点添加到头部,但顺序是颠倒的. 所以,在下面的例子中,执行Purge(清洗重复元素)的时候,没有

  • C语言*与&在操作线性表的作用详解

    在数据结构线性表一章,对线性表有这些操作方法(Operation): /*Operation*/ Initlist(*L);/*初始化操作,建立一个空的线性表L*/ ListEmpty(L):/*判断线性表是否为空表,若线性表为空,返回值为true,否则返回false*/ ClearList(*L):/*将线性表清空*/ GetElem(L,i,*e):/*性表L中的第i个位置元素值返回给e*/ LocateElem(L,e):/*在线性表L中查找与给定值e相等的元素,如果查找成功,返回该元素在

随机推荐