登录
/
注册
首页
论坛
其它
首页
科技
业界
安全
程序
广播
Follow
关于
导读
排行榜
资讯
发帖说明
登录
/
注册
账号
自动登录
找回密码
密码
登录
立即注册
搜索
搜索
关闭
CSDN热搜
程序园
精品问答
技术交流
资源下载
本版
帖子
用户
软件
问答
教程
代码
写记录
写博客
小组
VIP申请
VIP网盘
网盘
联系我们
发帖说明
道具
勋章
任务
淘帖
动态
分享
留言板
导读
设置
我的收藏
退出
腾讯QQ
微信登录
1
2
/ 2 页
下一页
返回列表
首页
›
业界区
›
科技
›
顺序表的初始化、插入、删除、遍历
顺序表的初始化、插入、删除、遍历
[ 复制链接 ]
国瑾瑶
2025-6-26 20:30:28
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
/*******************************************************************
*
* file name: seqlist.c
* author : MINDSETT@163.com
* date : 2025/6/19
* function : 该程序通过堆内存实现顺序表元素的增删改查,目的是提高设计程序的逻辑思维,另外为了提高可移植性,所以
* 顺序表中元素的数据类型为DataType_t,用户可以根据实际情况修改顺序表中元素的类型
* note : None
*
* CopyRight (c) 2025 MINDSETT@163.com All Right Reserved
*
* *****************************************************************/
#include <stdbool.h>
#include <stdlib.h>
#include <stdio.h>
//指定顺序表中的元素的数据类型,用户可根据需要进行修改
typedef int DataType_t;
//构造一个实现顺序表的各项参数(顺序表的首地址+顺序表的容量+顺序表最后有效元素的下标)的结构体
typedef struct Sequence_list
{
DataType_t * addr; //顺序表的首地址
unsigned int size; //顺序表的容量
int last; //顺序表最后有效元素的下标
}SeqList_t;
/********************************************************************
* name : Seqlist_Creat
* function : 创建一个顺序表并进行初始化
* argument :
* @size:创建的顺序表的大小
* retval : 返回顺序表管理结构体的首地址
* author : MINDSETT@163.com
* date : 2025/6/19
* note : None
*
* ******************************************************************/
SeqList_t *Seqlist_Creat(unsigned int size)
{
//1.利用calloc对顺序表的管理结构体申请一个内存
SeqList_t *manager=(SeqList_t *)calloc(1,sizeof(SeqList_t));
if (NULL == manager){
perror("calloc memory for manager is failed\n");
exit(-1);
}
//2.对顺序表管理结构体的所有元素进行初始化
manager->addr=(DataType_t *)calloc(size,sizeof(DataType_t));
if (NULL == manager->addr){
perror("calloc memory for element is failed\n");
exit(-1);
}
manager->size=size;
manager->last=-1;
return manager;
}
/********************************************************************
* name : Seqlist_IsFull
* function : 判断顺序表是否已满
* argument :
* @manager:需要判断的顺序表
* retval : 已满返回true,未满返回false
* author : MINDSETT@163.com
* date : 2025/6/19
* note : None
*
* ******************************************************************/
bool Seqlist_IsFull(SeqList_t *manager)
{
return (manager->last+1==manager->size)? true : false;
}
/********************************************************************
* name : Seqlist_IsEmpty
* function : 判断顺序表是否为空
* argument :
* @manager:需要判断的顺序表
* retval : 未满返回true,已满返回false
* author : MINDSETT@163.com
* date : 2025/6/19
* note : None
*
* ******************************************************************/
bool Seqlist_IsEmpty(SeqList_t *manager)
{
return (-1==manager->last)? true : false;
}
/********************************************************************
* name : Seqlist_TailAdd
* function : 从顺序表的尾部插入一个元素
* argument :
* @manager:需要操作的顺序表
* @Data:需要插入的元素
* retval : 成功返回true,失败返回false
* author : MINDSETT@163.com
* date : 2025/6/19
* note : None
*
* ******************************************************************/
bool Seqlist_TailAdd(SeqList_t *manager,DataType_t Data)
{
//判断顺序表是否已满
if ( Seqlist_IsFull(manager) ){
printf("sequence list is Full\n");
return false;
}
//如果顺序表有剩余空间,则把新元素插入顺序表的尾部,并更新管理结构体中最后有效元素的下标
manager->addr[++manager->last]=Data;
return true;
}
/********************************************************************
* name : Seqlist_HeadAdd
* function : 从顺序表的首部插入一个元素
* argument :
* @manager:需要操作的顺序表
* @Data:需要插入的元素
* retval : 成功返回true,失败返回false
* author : MINDSETT@163.com
* date : 2025/6/19
* note : None
*
* ******************************************************************/
bool Seqlist_HeadAdd(SeqList_t *manager,DataType_t Data)
{
//判断顺序表是否已满
if ( Seqlist_IsFull(manager) ){
printf("sequence list is Full\n");
return false;
}
//如果顺序表有空闲空间,将顺序表中的元素依次向后移1个单位
for (int i=manager->last;i>=0;i--){
manager->addr[i+1]=manager->addr[i];
}
//将新元素插入顺序表的尾部,并更新管理结构体中最后有效元素的下标
manager->addr[0]=Data;
manager->last++;
return true;
}
/********************************************************************
* name : Seqlist_Delete
* function : 删除数据表的一个元素
* argument :
* @manager:需要操作的顺序表
* @Data:需要删除的元素
* retval : 成功返回true,失败返回false
* author : MINDSETT@163.com
* date : 2025/6/19
* note : None
*
* ******************************************************************/
bool Seqlist_Delete(SeqList_t *manager,DataType_t Data)
{
//判断顺序表是否为空
if ( Seqlist_IsEmpty(manager) ){
printf("sequence list is empty\n");
return false;
}
//如果顺序表不为空,则判断该元素在顺序表中是否存在,如果存在,则判断数据在顺序表的尾部 OR 头部 OR 中间(*存在几个*)
int temp=-1;
for (int i=0;i<=manager->last;i++){
if(Data==manager->addr[i]){
temp=i;
break;
}
}
if (-1==temp){
printf("Data[%d] is not found\n",Data);
return false;
}
if (temp==manager->last){
manager->addr[manager->last]='\0';
}else if(temp==0){
for(int i=0;i<manager->last;i++)
manager->addr[i]=manager->addr[i+1];
manager->addr[manager->last]='\0';
}else{
for(int i=temp;i<manager->last;i++)
manager->addr[i]=manager->addr[i+1];
manager->addr[manager->last]='\0';
}
manager->last--;
return true;
}
/********************************************************************
* name : Seqlist_print
* function : 遍历顺序表
* argument :
* @manager:需要遍历的顺序表
* retval : None
* author : MINDSETT@163.com
* date : 2025/6/19
* note : None
*
* ******************************************************************/
void Seqlist_Print(SeqList_t *manager)
{
//判断顺序表是否为空
if ( Seqlist_IsEmpty(manager) ){
printf("sequence list is empty\n");
return;
}
//如果顺序表不为空,则打印顺序表的元素
for (int i=0;i<manager->last+1;i++){
printf("Element[%d]=%d\n",i,manager->addr[i]);
}
printf("\n");
}
复制代码
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
顺序
初始化
插入
删除
遍历
相关帖子
剑指offer-76、删除链表的节点
剑指offer-76、删除链表的节点
剑指offer-76、删除链表的节点
剑指offer-76、删除链表的节点
剑指offer-76、删除链表的节点
剑指offer-76、删除链表的节点
剑指offer-76、删除链表的节点
剑指offer-76、删除链表的节点
剑指offer-76、删除链表的节点
LangGraph4j 学习系列(1)-顺序工作流
回复
使用道具
举报
提升卡
置顶卡
沉默卡
喧嚣卡
变色卡
千斤顶
照妖镜
相关推荐
安全
剑指offer-76、删除链表的节点
1
11
昝琳怡
2026-02-12
安全
剑指offer-76、删除链表的节点
0
4
蔺堰
2026-02-12
安全
剑指offer-76、删除链表的节点
1
7
赖娅闺
2026-02-12
安全
剑指offer-76、删除链表的节点
3
18
赀倦
2026-02-12
安全
剑指offer-76、删除链表的节点
0
13
陶田田
2026-02-12
安全
剑指offer-76、删除链表的节点
3
9
赖琳芳
2026-02-12
安全
剑指offer-76、删除链表的节点
1
12
尤晓兰
2026-02-12
安全
剑指offer-76、删除链表的节点
3
10
董绣梓
2026-02-12
安全
剑指offer-76、删除链表的节点
0
8
驶桐柢
2026-02-12
安全
LangGraph4j 学习系列(1)-顺序工作流
2
455
夔新梅
2026-02-16
回复
(24)
决台
2025-11-27 16:50:46
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
鼓励转贴优秀软件安全工具和文档!
敛饺乖
2025-12-15 10:37:34
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
懂技术并乐意极积无私分享的人越来越少。珍惜
跑两獗
2025-12-23 15:36:20
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
喜欢鼓捣这些软件,现在用得少,谢谢分享!
赊朗爆
2025-12-24 23:09:44
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
不错,里面软件多更新就更好了
裴涛
2025-12-29 21:30:53
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
新版吗?好像是停更了吧。
訾懵
2026-1-15 17:25:43
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
感谢分享
替攀浮
2026-1-17 16:07:39
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
很好很强大 我过来先占个楼 待编辑
寨重
2026-1-18 00:43:40
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
感谢发布原创作品,程序园因你更精彩
役魅肋
2026-1-23 08:34:48
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
鼓励转贴优秀软件安全工具和文档!
米嘉怡
2026-1-24 08:33:43
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
这个好,看起来很实用
轮达
2026-1-24 08:45:59
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
前排留名,哈哈哈
佴莘莘
2026-1-27 02:26:20
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
收藏一下 不知道什么时候能用到
蔡如风
2026-1-30 07:43:38
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
谢谢分享,辛苦了
钦遭聘
2026-2-7 09:02:10
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
这个有用。
请蒂
2026-2-8 03:16:24
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
喜欢鼓捣这些软件,现在用得少,谢谢分享!
剩鹄逅
2026-2-8 13:36:07
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
用心讨论,共获提升!
劳暄美
2026-2-8 23:53:47
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
热心回复!
侧胥咽
2026-2-9 01:58:05
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
感谢分享,下载保存了,貌似很强大
赙浦
2026-2-9 09:28:40
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
用心讨论,共获提升!
下一页 »
1
2
/ 2 页
下一页
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
回复
本版积分规则
回帖并转播
回帖后跳转到最后一页
签约作者
程序园优秀签约作者
发帖
国瑾瑶
2026-2-9 09:28:40
关注
0
粉丝关注
18
主题发布
板块介绍填写区域,请于后台编辑
财富榜{圆}
3934307807
991124
anyue1937
9994892
kk14977
6845359
4
xiangqian
638210
5
宋子
9898
6
韶又彤
9918
7
闰咄阅
9993
8
刎唇
9995
9
蓬森莉
9883
10
遗憩
10006
查看更多
今日好文热榜
3
CSP-J2025游记
6
从挖矿木马入侵到 Docker Rootless 加固,
319
OpenClaw多Agent协作踩坑实录:从翻车到跑
713
【节点】[MainLightShadow节点]原理解析与
633
模拟退火算法
902
Claude Code 的 Skills 可以在 Trae IDE 中
254
付费 AI 用户和免费用户之间,究竟差了什么
699
手把手教你使用vscode开发stm32!
1003
“老东西,你懦弱了”——关于Vibe Coding
926
告别Hyprland/Niri键鼠共享难题:Pynergy
752
解惑|公司员工健身房需要哪些器材?上海皓
519
凸优化数学基础笔记(六):凸集、凸函数与
3
【强化学习的数学原理-赵世钰】随记
389
SeeDance2.0提示词之跳舞女孩
11
SeeDance2.0提示词之跳舞女孩
683
国内零门槛首个免费 开源 7×24小时帮
572
[拆解LangChain执行引擎]非常规Pending Wri
2
读人工智能全球格局:未来趋势与中国位势10
69
AI开发-python-milvus向量数据库(2-8 -mil
3
[LKD/Linux 内核] Linux 中的 进程, 线程