iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C++中顺序表操作的示例代码
  • 274
分享到

C++中顺序表操作的示例代码

C++顺序表操作C++顺序表 2022-11-13 18:11:20 274人浏览 泡泡鱼
摘要

编写程序,实现顺序表的下列功能: 从键盘输入数据建立一个顺序表输出该顺序表往顺序表中插入数据从顺序表中删除数据给定数据,进行查找,给出查找成功和失败信息 C++代码: #includ

编写程序,实现顺序表的下列功能:

  • 从键盘输入数据建立一个顺序表
  • 输出该顺序表
  • 往顺序表中插入数据
  • 从顺序表中删除数据
  • 给定数据,进行查找,给出查找成功和失败信息

C++代码:

#include <iOStream>
#include <string> 
#include "windows.h"
using namespace std;

// 定义顺序表结构体
struct SequentialList
{
	int* base;   // 顺序表首地址
	int length;  // 顺序表长度
	int count;	 // 顺序表当前元素个数
};

// 初始化结构体
bool initSequentialList(SequentialList& s) {
	
	// 如果之前已有数组,则释放之前的数组
	if (s.length >= 0) {
		delete s.base;
	}

	// 初始化一个长度为size数组
	int size;
	cout << "输入顺序表的长度:";
	cin >> size;
	s.base = new int[size];
	s.length = size;
	s.count = 0;
	// 清理屏幕
	system("cls||clear");
	// 判断初始化成功或失败
	if (s.base != NULL) {
		return true;
	}else {
		return false;
	}
}


// 打印顺序表各个元素
void printItems(SequentialList& s) {
	// 清理屏幕
	system("cls||clear");
	if (s.count > 0) {
		string temp(10, '-');
		cout << temp + "打印顺序表" + temp << endl;
		for (int i = 0; i < s.count; i++) {
			cout << "[" + to_string(i) + "]" + to_string(s.base[i]) << endl;
		}
	}
	else {
		cout << "无元素打印!" << endl;
	}
}

// 头插
bool topInsert(SequentialList& s, int item) {
	// 清理屏幕
	system("cls||clear");
	// 表满 操作失败
	if (s.count == s.length) {
		return false;
	}
	if (s.count > 0) {
		// 所有元素向后移动1位
		for (int i = s.count - 1; i >= 0; i--) {
			s.base[i + 1] = s.base[i];
		}
	}
	// 如果count为0 正常插入元素
	s.base[0] = item;
	s.count ++;
	return true;
}


// 尾插
bool bottomInsert(SequentialList& s, int item) {
	// 清理屏幕
	system("cls||clear");
	if (s.count == s.length) { // 表满->结束
		return false;
	}else {	// 没满直接尾插
		s.base[s.count] = item;
		s.count++;
		return true;
	}
}

// 指定位置插入
bool indexInsert(SequentialList& s, int index, int item) {
	// 清理屏幕
	system("cls||clear");
	// 判断下标是否给错 或者 表满 -> 结束
	if (0 > index || index > s.count || s.length == s.count) {
		return false;
	}
	if (index == 0) {
		// 调用头插
		topInsert(s, item);
	}else if (index == s.count) {
		// 调用尾插
		bottomInsert(s, item);
	}else {
		// index以及后面的所有元素 向后移动1位
		for (int i = s.count - 1; i >= index; i--) {
			s.base[i + 1] = s.base[i];
		}
		//插入操作
		s.base[index] = item;
		s.count++;
	}
	return true;

}

// 头删
bool topDelete(SequentialList& s) {
	// 清理屏幕
	system("cls||clear");
	// 如果没元素 -> 结束
	if (s.count == 0) {
		return false;
	}
	// 元素个数大于1 所有元素向前移动1位
	if (s.count > 1) {
		for (int i = 0; i < s.count - 1; i++) {
			s.base[i] = s.base[i + 1];
		}
	}
	s.count--;
	return true;
}

// 尾删
bool bottomDelete(SequentialList& s) {
	// 清理屏幕
	system("cls||clear");
	// 如果没元素 -> 结束
	if (s.count == 0) {
		return false;
	}
	// 伪删除
	s.count--;
	return true;
}

// 删除指定位置的元素
bool indexDelete(SequentialList& s, int index) {
	// 清理屏幕
	system("cls||clear");
	// 没元素 或 给错下标 -> 结束
	if (s.count == 0 || index < 0 || index >= s.count ) {
		return false;
	}

	if (index == 0) {
		// 调用头删
		topDelete(s);
	}else if (index == s.count) {
		// 调用尾删
		bottomDelete(s);
	}else {
		// index后面的元素向前覆盖
		for (int i = index; i < s.count - 1; i++) {
			s.base[i] = s.base[i + 1];
		}
		s.count--;
	}
	return true;
}

// 查找某元素在顺序表的位置
void findElement(SequentialList& s, int item) {
	// 清理屏幕
	system("cls||clear");
	// -1为找不到
	int count = 0;
	// 匹配
	for (int i = 0; i < s.count; i++) {
		if (s.base[i] == item) {
			count++;
			cout << "找到第" + to_string(count) + "个"+to_string(item)+"的下标为["+to_string(i)+"]" << endl;
		}	
	}
	if (count == 0) {
		cout << "未找到" + to_string(item) + "元素!" << endl;
	}
}

// 打印菜单
void printMenu(){
	string temp(10, '-');
	cout << endl;
	cout << temp+"操作菜单"+temp << endl;
	cout << "[1]建立一个顺序表" << endl;
	cout << "[2]打印顺序表" << endl;
	cout << "[3]向顺序表[头部]插入新元素" << endl;
	cout << "[4]向顺序表[尾部]插入新元素" << endl;
	cout << "[5]向顺序[指定位置]部插入新元素" << endl;
	cout << "[6]删除顺序表[头部]的元素" << endl;
	cout << "[7]删除顺序表[尾部]的元素" << endl;
	cout << "[8]删除顺序表[指定位置]的元素" << endl;
	cout << "[9]查找某元素在顺序表的位置" << endl;
	cout << "[0]退出操作" << endl;
	cout << temp+temp+temp << endl;
}
// 函数主入口
int main() {
	int options;			// 选项
	int flag = true;		// while循环标记
	SequentialList s;		// 顺序表结构体变量
	int newItem;			// 新元素
	int index;				// 插入|删除元素的下标
	while (flag) {
		printMenu();
		cout << "请操作:" ;
		cin >> options;
		switch (options) {
			case 1:
				if (initSequentialList(s)) {
					cout << "\t初始化成功" << endl;
				}
				else {
					cout << "\t初始化失败" << endl;
				}
				break;
			case 2:
				printItems(s);
				break;
			case 3:
				cout << "新元素:";
				cin >> newItem;
				
				if (topInsert(s, newItem)) {
					cout << "头部成功插入("+ to_string(newItem)+")" << endl;
				}
				else {
					cout << "顺序表已满,头部插入操作失败!!!" << endl;
				}
				break;
			case 4:
				cout << "新元素:";
				cin >> newItem;

				if (bottomInsert(s, newItem)) {
					cout << "尾部成功插入(" + to_string(newItem) + ")!!!" << endl;
				}
				else {
					cout << "顺序表已满,尾部插入操作失败!!!" << endl;
				}
				break;
			case 5:
				cout << "新元素:";
				cin >> newItem;
				cout << "插入位置:";
				cin >> index;
				if (indexInsert(s, index, newItem)) {
					cout << "在["+to_string(index) + "]成功插入(" + to_string(newItem) + ")!!!" << endl;
				}
				else {
					cout << "插入位置错误或顺序表已满,操作失败!!!" << endl;
				}
				break;
			case 6:
				if (topDelete(s)) {
					cout << "头部元素删除成功!!!" << endl;
				}
				else {
					cout << "头部元素删除操作失败!!!" << endl;
				}
				break;
			case 7:
				if (bottomDelete(s)) {
					cout << "尾部元素删除成功!!!" << endl;
				}
				else {
					cout << "尾部元素删除操作失败!!!" << endl;
				}
				break;
			case 8:
				cout << "删除位置:";
				cin >> index;
				if (indexDelete(s, index)) {
					cout <<"删除[" + to_string(index) + "]元素成功!!!" << endl;
				}
				else {
					cout << "删除位置错误或顺序表为空,操作失败!!!" << endl;
				}
				break;
			case 9:
				cout << "要查找的元素:";
				cin >> newItem;
				findElement(s, newItem);
				break;
			case 0:
				// 清理屏幕
				system("cls||clear");
				flag = false;
				cout << "---本次操作结束---" << endl;
				break;
			default:
				cout << "请输入正确的序号!!!" << endl;
				break;
		}
	}
	return 0;
}

运行结果:

到此这篇关于c++中顺序表操作的示例代码的文章就介绍到这了,更多相关C++顺序表操作内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: C++中顺序表操作的示例代码

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

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

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • C++中顺序表操作的示例代码
    编写程序,实现顺序表的下列功能: 从键盘输入数据建立一个顺序表输出该顺序表往顺序表中插入数据从顺序表中删除数据给定数据,进行查找,给出查找成功和失败信息 C++代码: #includ...
    99+
    2022-11-13
    C++顺序表操作 C++ 顺序表
  • C/C++实现线性顺序表的示例代码
    目录线性顺序表简介C语言实现代码C++语言实现代码线性顺序表简介 使用顺序存储结构的线性存储结构的表为线性顺序表,线性存储结构是元素逻辑结构一对一,顺序存储结构是元素物理结构连续,线...
    99+
    2022-11-13
  • C语言实现动态顺序表的示例代码
    目录顺序表概念及结构基本操作功能实现程序运行顺序表概念及结构 顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储。在数组上完成数据的增删查改。 分...
    99+
    2022-11-13
    C语言 动态顺序表 C语言 顺序表
  • C++中单链表操作的示例代码
    任务要求 实现单链表的下列功能: 1、 从键盘输入一组数据,创建单链表; 2、 输出单链表; 3、 插入元素,给出插入成功或失败的信息; 4、 头插,给出插入成功或失败的信息; 5、...
    99+
    2022-11-13
    C++ 单链表
  • C#中顺序表的示例分析
    这篇文章主要为大家展示了“C#中顺序表的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“C#中顺序表的示例分析”这篇文章吧。首先来看看看C#数据结构与算法之顺序表的概念:C#数据结构与算法...
    99+
    2023-06-18
  • C语言动态顺序表实例代码
    目录顺序表概念:一.准备工作二、顺序表的基本操作 1.顺序表的初始化函数2.尾插函数(在尾部插入数据)3.头插函数(在数组头部插入数据) 4.尾删函数5.头删函数6.在第pos的位置...
    99+
    2022-11-12
  • C语言实现顺序表的基本操作的示例详解
    目录一、认识顺序表1.线性表2.顺序表的概念及结构二、顺序表的基本操作(接口实现)1.初始化顺序表2.打印顺序表3.尾插4.尾删5.扩容6.头插7.头删8.任意位置插入9.任意位置删...
    99+
    2022-11-13
    C语言顺序表基本操作 C语言顺序表操作 C语言顺序表
  • C语言线性表中顺序表的示例分析
    小编给大家分享一下C语言线性表中顺序表的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、本章重点线性表和顺序表的概念动态和静态顺序表接口实现在线0j训练...
    99+
    2023-06-29
  • C++顺序表的基本操作实现
    目录1.顺序表的定义2.顺序表上基本操作的实现完整代码如下:总结1.顺序表的定义 线性表的顺序存储又称顺序表。它是用一组地址连续的存储单元依次存储线性表中的数据元素,从而使得逻辑上相...
    99+
    2022-11-13
  • Python数据结构之顺序表的实现代码示例
    顺序表即线性表的顺序存储结构。它是通过一组地址连续的存储单元对线性表中的数据进行存储的,相邻的两个元素在物理位置上也是相邻的。比如,第1个元素是存储在线性表的起始位置LOC(1),那么第i个元素即是存储在L...
    99+
    2022-06-04
    数据结构 示例 顺序
  • C语言动态顺序表实例代码怎么编写
    这篇文章给大家介绍C语言动态顺序表实例代码怎么编写,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。顺序表概念:        顺序表是用一段物理地址连续的存储单元依次存储数据元素的...
    99+
    2023-06-22
  • C语言怎么实现顺序表的操作
    这篇文章主要介绍了C语言怎么实现顺序表的操作的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C语言怎么实现顺序表的操作文章都会有所收获,下面我们一起来看看吧。线性表线性表(linear list)是n个具有相同特...
    99+
    2023-06-30
  • C语言实现串的顺序存储表示与基本操作
    本文实例为大家分享了C语言实现串的顺序存储表示与基本操作代码,供大家参考,具体内容如下 1、串的三种存储表示 串,即:字符串。要注意的是,C语言中是没有字符串数据类型的,而将其作为一...
    99+
    2022-11-12
  • C语言制作表白神器的示例代码
    目录程序说明操作说明程序效果完整源码程序说明 这是一个表白神器,可以自己替换上图片识别。 1.程序默认是识别 640×480 尺寸,可以自己调整。 2.也有现成的程序可以...
    99+
    2023-03-07
    C语言制作表白神器 C语言表白神器 C语言表白
  • C语言实现顺序表的全操作详解
    目录线性表顺序表顺序表接口实现1.顺序表初始化2.顺序表空间增容3.顺序表打印4.尾插数据5.尾删数据6.头插数据7.头删数据8.在pos下标处插入数据9.删除pos下标处数据10....
    99+
    2022-11-13
  • Java中保证线程顺序执行的操作代码
    只要了解过多线程,我们就知道线程开始的顺序跟执行的顺序是不一样的。如果只是创建三个线程然后执行,最后的执行顺序是不可预期的。这是因为在创建完线程之后,线程执行的开始时间取决于CPU何...
    99+
    2022-11-12
  • golang操作rocketmq的示例代码
    RocketMQ 是什么 Github 上关于 RocketMQ 的介绍:RcoketMQ 是一款低延迟、高可靠、可伸缩、易于使用的消息中间件。具有以下特性: 支持发布/订阅(Pub...
    99+
    2022-11-13
  • C++ 实现桶排序的示例代码
    目录原理实现步骤:模拟生成整数随机数桶排序实现完整版可运行程序时间复杂度计算桶排序:整数  原理 原理简述:按照需要排序数组的实际情况,生成一个一定长度的一维数组,用于统计...
    99+
    2022-11-12
  • c++实现堆排序的示例代码
    看了一下优先队列,查了一下堆排序。堆排序主要就是建最大堆(最小堆)和交换2个操作。如果建的是最大堆,那么交换的时候,父节点就和最大的子节点比较,如果它比最大的子节点还大,那就不用比了...
    99+
    2023-02-02
    c++ 堆排序
  • C/C++实现线性单链表的示例代码
    目录线性单链表简介C语言实现代码C++语言实现代码线性单链表简介 使用链存储结构的线性存储结构为线性单链表,线性存储结构是元素逻辑结构一对一,链存储结构是元素物理结构不连续,线性单链...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作