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

作者:我不是秃头sheep 时间:2022-05-12 17:39:52 

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

  • 从键盘输入数据建立一个顺序表

  • 输出该顺序表

  • 往顺序表中插入数据

  • 从顺序表中删除数据

  • 给定数据,进行查找,给出查找成功和失败信息

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++中顺序表操作的示例代码

来源:https://blog.csdn.net/weixin_44864260/article/details/127404654

标签:C++,顺序表,操作
0
投稿

猜你喜欢

  • android实现扑克卡片翻转

    2021-10-19 08:08:35
  • IOS 实现摇一摇的操作

    2023-07-02 13:46:53
  • springboot 整合fluent mybatis的过程,看这篇够了

    2022-09-14 01:16:53
  • Spring+EHcache缓存实例详解

    2023-12-12 20:27:51
  • Android仿微信朋友圈图片查看器

    2023-01-27 18:07:20
  • Java学习关于循环和数组练习题整理

    2022-07-19 21:01:24
  • Java二叉搜索树基础原理与实现方法详解

    2022-09-12 17:20:59
  • c#数据绑定之linq使用示例

    2022-07-17 11:07:22
  • spring装配bean的3种方式总结

    2023-01-05 07:01:47
  • java多线程编程学习(线程间通信)

    2023-04-02 05:25:34
  • SpringBoot集成阿里云OSS图片上传

    2021-08-15 21:01:55
  • java组件commons-fileupload实现文件上传

    2022-10-02 08:33:14
  • Java由浅入深带你了解什么是包package

    2022-04-17 02:33:39
  • IDEA全量替换一次性解决旧项目并将所有文件换行符改为LF问题

    2022-09-17 18:44:32
  • java中request常用方法小结

    2022-09-13 06:19:45
  • spring validation多层对象校验教程

    2023-11-27 15:17:49
  • Spring Security前后分离校验token的实现方法

    2023-06-26 17:00:30
  • Springboot中Aspect切面的实现方式(以记录日志为例)

    2022-09-15 20:58:25
  • 如何解决springmvc文件下载,内容损坏的问题

    2023-10-11 07:12:10
  • C++实现优先队列的示例详解

    2022-04-06 22:14:20
  • asp之家 软件编程 m.aspxhome.com