表篇(一)----顺序表的创建与使用(C语言版)

2024-02-22 11:32

本文主要是介绍表篇(一)----顺序表的创建与使用(C语言版),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本篇博客是整理数据结构知识的第一篇博客,由于本人也刚接触数据结构,所以这篇最简单的顺序表的创建,写了好久好久,都快想放弃掉了。
但是还是一点一点坚持下来了,所以希望广大读者也可以坚持学习数据结构,坚持看我的数据结构总结博客。

本篇文章主要介绍了顺序表的创建,初始化,查找某元素在顺序表中的位序,插入,删除,循环遍历,内容简单。
#include<stdio.h>
#include<stdlib.h>    //malloc函数头文件
typedef struct{int *elem;int length;int maxlength;
}SqList;bool InitList(SqList &L,int size){  //数据表的创建L.maxlength = size;L.elem = (int *)malloc(sizeof(SqList));     //给顺序表创建动态空间if (!L.elem){return	false;}L.length = 0;return true;
}
void Be(SqList &L){                //数据表初始存放数据printf("初始状态顺序表的长度:\n");scanf_s("%d", &L.length);printf("请输入你要创建的顺序表:\n");for (int i = 0; i < L.length; i++){scanf_s("%d", &L.elem[i]);   //存入的值从数组0开始}
}
int LocateElem(SqList L, int e){           //查找某元素在数据表中的位序  for (int i = 0; i < L.length; i++){if (L.elem[i] == e){return i + 1;}}return 0;
}
bool ListInsert(SqList &L, int i, int e){      //向顺序表中某位置插入一个元素if (i<1 || i>L.length + 1){return false;}if (L.length == L.maxlength){return false;}for (int j = L.length-1 ; j >= i-1; j--){   //确定数组移动范围从最后到位序为i的数组i-1位置L.elem[j + 1] = L.elem[j];         //将第n个至第i个位置的元素依次向后移动一个位置,空出第i个位置}L.elem[i-1] = e;                  //位序从1开始,但数组从0开始++L.length;return true;
}bool ListDelete(SqList &L, int i, int &e){          //删除顺序表中某位置元素if (i<1 || i>L.length ){return false;}e = L.elem[i - 1];for (int j = i; j <L.length; j++){             //确定数组移动范围为从位序为i+1的数组i位置到最后L.elem[j - 1] = L.elem[j];           //将第i+1个至第n个的元素依次向前移动一个位置}--L.length;return true;
}void ListTraverse(SqList &L){                    //遍历输出顺序表for (int i = 0; i < L.length; i++){printf("%d", L.elem[i]);}
}int main(){
int i,j,g;
SqList L;
printf("顺序表最大长度:\n");
scanf_s("%d", &i);    //输入顺序表最大长度
InitList(L,i);        //创建顺序表
Be(L);                //初始化数据表,这里事例为:1,2,3,4
ListInsert(L, 5, 7);  //向数据表目前最后一个位置插入数据
ListDelete(L, 1,j);   //删除数据表第一个位置的元素
printf("%d\n", j);    //输出删除的元素值
ListTraverse(L);      //遍历输出现在的顺序表
printf("\n");         //换行
g=LocateElem(L, 3);   //查看此时顺序表中元素值为3的位置
printf("%d\n", g);    //输出位置
return 0;
}

这篇关于表篇(一)----顺序表的创建与使用(C语言版)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/735125

相关文章

使用Python实现高效的端口扫描器

《使用Python实现高效的端口扫描器》在网络安全领域,端口扫描是一项基本而重要的技能,通过端口扫描,可以发现目标主机上开放的服务和端口,这对于安全评估、渗透测试等有着不可忽视的作用,本文将介绍如何使... 目录1. 端口扫描的基本原理2. 使用python实现端口扫描2.1 安装必要的库2.2 编写端口扫

MySQL分表自动化创建的实现方案

《MySQL分表自动化创建的实现方案》在数据库应用场景中,随着数据量的不断增长,单表存储数据可能会面临性能瓶颈,例如查询、插入、更新等操作的效率会逐渐降低,分表是一种有效的优化策略,它将数据分散存储在... 目录一、项目目的二、实现过程(一)mysql 事件调度器结合存储过程方式1. 开启事件调度器2. 创

使用Python实现操作mongodb详解

《使用Python实现操作mongodb详解》这篇文章主要为大家详细介绍了使用Python实现操作mongodb的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、示例二、常用指令三、遇到的问题一、示例from pymongo import MongoClientf

SQL Server使用SELECT INTO实现表备份的代码示例

《SQLServer使用SELECTINTO实现表备份的代码示例》在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误,在SQLServer中,可以使用SELECTINT... 在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误。在 SQL Server 中,可以使用 SE

使用Python合并 Excel单元格指定行列或单元格范围

《使用Python合并Excel单元格指定行列或单元格范围》合并Excel单元格是Excel数据处理和表格设计中的一项常用操作,本文将介绍如何通过Python合并Excel中的指定行列或单... 目录python Excel库安装Python合并Excel 中的指定行Python合并Excel 中的指定列P

浅析Rust多线程中如何安全的使用变量

《浅析Rust多线程中如何安全的使用变量》这篇文章主要为大家详细介绍了Rust如何在线程的闭包中安全的使用变量,包括共享变量和修改变量,文中的示例代码讲解详细,有需要的小伙伴可以参考下... 目录1. 向线程传递变量2. 多线程共享变量引用3. 多线程中修改变量4. 总结在Rust语言中,一个既引人入胜又可

golang1.23版本之前 Timer Reset方法无法正确使用

《golang1.23版本之前TimerReset方法无法正确使用》在Go1.23之前,使用`time.Reset`函数时需要先调用`Stop`并明确从timer的channel中抽取出东西,以避... 目录golang1.23 之前 Reset ​到底有什么问题golang1.23 之前到底应该如何正确的

mysql外键创建不成功/失效如何处理

《mysql外键创建不成功/失效如何处理》文章介绍了在MySQL5.5.40版本中,创建带有外键约束的`stu`和`grade`表时遇到的问题,发现`grade`表的`id`字段没有随着`studen... 当前mysql版本:SELECT VERSION();结果为:5.5.40。在复习mysql外键约

详解Vue如何使用xlsx库导出Excel文件

《详解Vue如何使用xlsx库导出Excel文件》第三方库xlsx提供了强大的功能来处理Excel文件,它可以简化导出Excel文件这个过程,本文将为大家详细介绍一下它的具体使用,需要的小伙伴可以了解... 目录1. 安装依赖2. 创建vue组件3. 解释代码在Vue.js项目中导出Excel文件,使用第三

Linux alias的三种使用场景方式

《Linuxalias的三种使用场景方式》文章介绍了Linux中`alias`命令的三种使用场景:临时别名、用户级别别名和系统级别别名,临时别名仅在当前终端有效,用户级别别名在当前用户下所有终端有效... 目录linux alias三种使用场景一次性适用于当前用户全局生效,所有用户都可调用删除总结Linux