我的编程空间,编程开发者的网络收藏夹
学习永远不晚

C++如何实现数据结构的顺序表

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

C++如何实现数据结构的顺序表

这篇文章给大家分享的是有关C++如何实现数据结构的顺序表的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

    代码

    1.SeqList.h

    #ifndef SEQLIST_H#define SEQLIST_H#include<iostream>using namespace std;template<class T,int MAXSIZE>class SeqList{T data[MAXSIZE];int length;public:SeqList();SeqList(T a[],int n);~SeqList();int ListLength();T Get(int pos);int Locate(T item);void SeqPrint();void Insert(int i, T item);T Delete(int i);};#endif

    2.SeqList.cpp

    #define _CRT_SECURE_NO_WARNINGS   1#include"SeqList.h"template<class T, int MAXSIZE>SeqList<T,MAXSIZE>::SeqList(){length = 0;}template<class T, int MAXSIZE>SeqList<T, MAXSIZE>::SeqList(T a[], int n){if (n < MAXSIZE){length = n;for (int i = 0; i < n; i++){data[i] = a[i];}}else{cerr << "您的数据已经超过范围,系统无法继续工作" << endl;exit(-1);}}template<class T, int MAXSIZE>SeqList<T, MAXSIZE>::~SeqList(){}template<class T, int MAXSIZE>int SeqList<T, MAXSIZE>::ListLength(){return length;}template<class T, int MAXSIZE>T SeqList<T, MAXSIZE>::Get(int pos){if (pos > length || pos < 0){cerr << "您要查找的位置不存在,系统无法继续为您服务" << endl;exit(-1);}else{return data[pos - 1];}}template<class T, int MAXSIZE>int SeqList<T, MAXSIZE>::Locate(T item){for (int i = 0; i < length; i++){if (data[i] == item)return i + 1;}return -1;}template<class T, int MAXSIZE>void SeqList<T, MAXSIZE>::SeqPrint(){for (int i = 0; i < length; i++){cout << data[i] << "  ";}cout << endl;}template<class T, int MAXSIZE>void SeqList<T, MAXSIZE>::Insert(int i, T item){if (length < MAXSIZE){for (int j = length - 1; j>=i - 1; j--){data[j + 1] = data[j];}data[i - 1] = item;length++;}else{cerr << "抱歉,当前已经达到系统最大的储存,无法为您插入" << endl;exit(-1);}}template<class T, int MAXSIZE>T SeqList<T, MAXSIZE>::Delete(int i){if (length == 0){cerr << "当前无可删除元素" << endl;exit(-1);}if (i<1 || i>length){cerr << "该位置非法" << endl;exit(-1);}T x = data[i - 1];for (int j = i; j < length; j++){data[j - 1] = data[j];}length--;return x;}

    3.test.cpp

    #define _CRT_SECURE_NO_WARNINGS   1#include"SeqList.cpp"#include<iostream>using namespace std;void menu(){cout << "|------------------------------------|" << endl;cout << "|----------- 欢迎来到顺序表 ---------|" << endl;cout << "|---------------1.插入---------------|" << endl;cout << "|---------------2.删除---------------|" << endl;cout << "|---------------3.求长---------------|" << endl;cout << "|---------------4.取值---------------|" << endl;cout << "|---------------5.定位---------------|" << endl;cout << "|---------------6.打印---------------|" << endl;cout << "|---------------0.退出---------------|" << endl;cout << "|------------------------------------|" << endl;}int main(){int *a;int n;cout << "请输入您要构造的顺序表的长度" << endl;cin >> n;a = new int[n];cout << "请输入该顺序表中的每一个元素" << endl;for (int i = 0; i < n; i++){cin >> a[i];}SeqList<int, 20>seq(a, n);cout << "现在开始我们的程序之旅" << endl;int input=0;do{menu();cout << "输入您要进行的操作的编号" << endl;cin >> input;switch (input){case 1:cout << "请输入您要插入的位置和数值" << endl;int pos;int value;cin >> pos;cin >> value;seq.Insert(pos,value);break;case 2:cout << "请输入您要删除的位置" << endl;int pos1;cin >> pos1;cout << "您删除的元素的值为:";cout << seq.Delete(pos1) << endl;break;case 3:cout << "您的顺序表当前的长度为:" << seq.ListLength() << endl;break;case 4:cout << "请输入您要查找的位置" << endl;int pos2;cin >> pos2;cout << "您查找的元素的值为:";cout << seq.Get(pos2) << endl;;break;case 5:cout << "请输入您要查找的元素" << endl;int item;cin >> item;cout << "您查找的元素的位置为:";cout << seq.Locate(item) << endl;;break;case 6:cout << "当前顺序表如下:" << endl;seq.SeqPrint();break;case 0:cout << "程序退出,感谢使用" << endl;exit(-1);break;default :cout << "您的输入有误,请重新选择" << endl;}} while (input);return 0;}

    感谢各位的阅读!关于“C++如何实现数据结构的顺序表”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    C++如何实现数据结构的顺序表

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档

    猜你喜欢

    C++如何实现数据结构的顺序表

    这篇文章给大家分享的是有关C++如何实现数据结构的顺序表的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。代码1.SeqList.h#ifndef SEQLIST_H#define SEQLIST_H#include
    2023-06-25

    C语言数据结构顺序表怎么构造

    本篇内容介绍了“C语言数据结构顺序表怎么构造”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!前言在学习链表之前先掌握顺序表什么是顺序表?顺序表
    2023-06-30

    Java数据结构之ArrayList从顺序表到实现

    Java中的ArrayList是一种基于数组实现的数据结构,支持动态扩容和随机访问元素,可用于实现顺序表等数据结构。ArrayList在内存中连续存储元素,支持快速的随机访问和遍历。通过学习ArrayList的实现原理和使用方法,可以更好地掌握Java中的数据结构和算法
    2023-05-18

    Python数据结构之顺序表的实现代码示例

    顺序表即线性表的顺序存储结构。它是通过一组地址连续的存储单元对线性表中的数据进行存储的,相邻的两个元素在物理位置上也是相邻的。比如,第1个元素是存储在线性表的起始位置LOC(1),那么第i个元素即是存储在LOC(1)+(i-1)*sizeo
    2022-06-04

    C++数据结构之哈希表如何实现

    本篇内容主要讲解“C++数据结构之哈希表如何实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C++数据结构之哈希表如何实现”吧!哈希表概念二叉搜索树具有对数时间的表现,但这样的表现建立在一个假
    2023-07-05

    C++数据结构之单链表如何实现

    这篇文章主要介绍了C++数据结构之单链表如何实现的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C++数据结构之单链表如何实现文章都会有所收获,下面我们一起来看看吧。一、单链表的定义线性表的链式存储又称为单链表,
    2023-06-30

    Java数据结构的顺序表怎么操作

    这篇文章主要介绍了Java数据结构的顺序表怎么操作的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Java数据结构的顺序表怎么操作文章都会有所收获,下面我们一起来看看吧。前言线性表(linear list)是n个
    2023-06-29

    如何分析Python数据结构与算法中的顺序表

    这篇文章的内容主要围绕如何分析Python数据结构与算法中的顺序表进行讲述,文章内容清晰易懂,条理清晰,非常适合新手学习,值得大家去阅读。感兴趣的朋友可以跟随小编一起阅读吧。希望大家通过这篇文章有所收获!0. 学习目标线性表在计算机中的表示
    2023-06-26

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录