返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C++如何实现数据结构的顺序表
  • 220
分享到

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

2023-06-25 15:06:37 220人浏览 独家记忆
摘要

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

这篇文章给大家分享的是有关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++如何实现数据结构的顺序表”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

    --结束END--

    本文标题: C++如何实现数据结构的顺序表

    本文链接: https://lsjlt.com/news/305688.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    猜你喜欢
    • C++如何实现数据结构的顺序表
      这篇文章给大家分享的是有关C++如何实现数据结构的顺序表的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。代码1.SeqList.h#ifndef SEQLIST_H#define SEQLIST...
      99+
      2023-06-25
    • C++实现数据结构的顺序表详解
      目录前言:代码1.SeqList.h2.SeqList.cpp3.test.cpp总结 前言: hello,大家好,这篇文章博主来分享一下C++实现数据结构中的顺序表的代码。希望对大...
      99+
      2024-04-02
    • Java数据结构之顺序表的实现
      目录前言一、顺序表1.1 什么是顺序表二、简单实现顺序表2.1 创建顺序表2.2 打印顺序表2.3 获取顺序表长度2.4 在 pos 位置新增元素2.5 判定是否包含某个元素2.6 ...
      99+
      2024-04-02
    • C语言数据结构顺序表怎么构造
      本篇内容介绍了“C语言数据结构顺序表怎么构造”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!前言在学习链表之前先掌握顺序表什么是顺序表?顺序表...
      99+
      2023-06-30
    • Java数据结构之ArrayList从顺序表到实现
      目录1 ArrayList2 ArrayList使用2.1 ArrayList的构造2.2 ArrayList常见操作2.3 ArrayList的遍历2.4 ArrayList的扩容...
      99+
      2023-05-18
      Java ArrayList Java ArrayList顺序表
    • C++ 数据结构超详细讲解顺序表
      目录前言一、顺序表是什么概念及结构二、顺序表的实现顺序表的缺点几道练手题总结(●’◡’●) 前言 线性表是n个具有相同特性的数据元素的有限序列。线性表是一种...
      99+
      2024-04-02
    • C语言数据结构之顺序表和单链表
      一、顺序表的创建、删除和插入 #define _CRT_SECURE_NO_WARNINGS 1 #include<stdio.h> struct sqlist { ...
      99+
      2024-04-02
    • Java数据结构之顺序表篇
      目录一.线性表 二.顺序表1.概念及结构2.顺序表的实现打印顺序表获取顺序表的有效长度在pos位置新增元素判断是否包含某个元素查找某个元素对应的位置获取/查找pos位置的元...
      99+
      2024-04-02
    • Python数据结构之顺序表的实现代码示例
      顺序表即线性表的顺序存储结构。它是通过一组地址连续的存储单元对线性表中的数据进行存储的,相邻的两个元素在物理位置上也是相邻的。比如,第1个元素是存储在线性表的起始位置LOC(1),那么第i个元素即是存储在L...
      99+
      2022-06-04
      数据结构 示例 顺序
    • Java实现顺序表和链表结构
      目录前言:顺序表定义:实现方法:代码实现:链表定义:分类:实现方法:代码实现:顺序表 & 链表总结前言: 线性表(linear list)是n个具有相同特性的数据元素的有限序...
      99+
      2024-04-02
    • C语言数据结构顺序表的进阶讲解
      目录前言一、顺序表的构造VS功能1.顺序表的构造2.接口实现(功能)二、功能具体分析1.初始化2.销毁3.检查size与capacity是否溢出4.尾增功能(实现)5.打印三、实现具...
      99+
      2024-04-02
    • C语言数据结构深入探索顺序表
      目录1.线性表2.顺序表2.1概念及结构2.2 接口实现2.2.1初始化2.2.2 检查容量2.2.3 顺序表打印2.2.4 顺序表尾插2.2.5 顺序表尾删2.2.6 顺序表头插2...
      99+
      2024-04-02
    • C语言 数据结构之数组模拟实现顺序表流程详解
      目录线性表和顺序表线性表顺序表静态顺序表动态顺序表代码已经放在Gitee上,需要可以小伙伴可以去看看 用C语言数组模拟实现顺序表 Gitee 线性表和顺序表 线性表 线性表(line...
      99+
      2024-04-02
    • C++数据结构之单链表如何实现
      这篇文章主要介绍了C++数据结构之单链表如何实现的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C++数据结构之单链表如何实现文章都会有所收获,下面我们一起来看看吧。一、单链表的定义线性表的链式存储又称为单链表,...
      99+
      2023-06-30
    • C++数据结构之哈希表如何实现
      本篇内容主要讲解“C++数据结构之哈希表如何实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C++数据结构之哈希表如何实现”吧!哈希表概念二叉搜索树具有对数时间的表现,但这样的表现建立在一个假...
      99+
      2023-07-05
    • Java数据结构顺序表的详细讲解
      目录写在前面1.线性表2.顺序表的实现2.1增加数据2.1.1尾部增加数据2.1.2任意位置增加数据2.2查找数据2.3删除数据2.4修改数据3.ArrayList3.1ArrayL...
      99+
      2024-04-02
    • Java数据结构的顺序表怎么操作
      这篇文章主要介绍了Java数据结构的顺序表怎么操作的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Java数据结构的顺序表怎么操作文章都会有所收获,下面我们一起来看看吧。前言线性表(linear list)是n个...
      99+
      2023-06-29
    • Java 精炼解读数据结构的顺序表如何操作
      目录前言一、什么是顺序表顺序表的概念及结构创建顺序表打印顺序表获取顺序表长度在pos位置新增元素判定是否包含某个元素查找某个元素对应的位置获取 pos 位置的元素给 pos 位置的元...
      99+
      2024-04-02
    • 如何分析Python数据结构与算法中的顺序表
      这篇文章的内容主要围绕如何分析Python数据结构与算法中的顺序表进行讲述,文章内容清晰易懂,条理清晰,非常适合新手学习,值得大家去阅读。感兴趣的朋友可以跟随小编一起阅读吧。希望大家通过这篇文章有所收获!0. 学习目标线性表在计算机中的表示...
      99+
      2023-06-26
    • Java数据结构顺序表用法详解
      目录1.什么是顺序表2.顺序表的基本功能和结构3.顺序表基本功能的实现和解析1.判断线性表是否为空2.获取指定位置的元素3.向线性表表添加元素4.在位置i处插入元素5.删除指定位置的...
      99+
      2024-04-02
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作