顺序表中静态顺序表的创建、插入和删除一个元素(源码分析)

2024-06-19 16:08

本文主要是介绍顺序表中静态顺序表的创建、插入和删除一个元素(源码分析),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在数据结构的开始,首要讲的是顺序表,顺序表分为静态顺序表和动态顺序表

1、静态顺序表

      个人认为,静态顺序表和数组并不二样,静态的一张表,首要必须确定元素的个数,比如这样写

      typedef MaxSoze 10 ; 

      int a[MaxSize];

      想想数组的定义,也是确定元素的个数

    静态顺序表的创建就可以了

下面是对这张顺序表进行操作,简单的有插入一个元素,删除一个元素,插入一个元素的思想是首先要把自该位置起的所有元素往后移动一位,然后把要插的元素放在该位置,但要注意的是判断的条件,比如要插入的元素的位置是否是符合原顺序表的等等

删除元素的操作类似,把待删除元素之后的每一个元素往前移动一位,这样就把待删除的元素给抹掉了,同样是要注意判断条件的正确性

     另外,既然要插入元素,记得把表的长度加1,删除元素,记得把表的长度减1


下面是部分代码:

/* 删除函数中
*  len :表示是删除一个元素的位置
*  n   :表示表的长度
*/ 
void DeleteElem(int a[],int len,int *n)
{
int i=0;
if(len<1 || len >(*n) )
{
printf("error!\n");
return;
}
for(i=len;i<(*n);i++)
a[i-1]=a[i];
*n-=1;
}


/* 插入函数中
*  m  :表示待插入的元素的大小
*  len:表示要插入的位置
*  n  :表的长度
*/ 
void InsertElem(int a[],int m,int len,int *n)
{
int i=0;
if(len <1 || len >(*n) || (*n) == MaxSize)
{
printf("error!\n");
return ;
}
for(i=(*n-1);i>=(len-1);i--)
a[i+1]=a[i];
a[len-1] = m;
*n+=1;
}

这篇关于顺序表中静态顺序表的创建、插入和删除一个元素(源码分析)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

Nginx分布式部署流程分析

《Nginx分布式部署流程分析》文章介绍Nginx在分布式部署中的反向代理和负载均衡作用,用于分发请求、减轻服务器压力及解决session共享问题,涵盖配置方法、策略及Java项目应用,并提及分布式事... 目录分布式部署NginxJava中的代理代理分为正向代理和反向代理正向代理反向代理Nginx应用场景

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他

Redis中的有序集合zset从使用到原理分析

《Redis中的有序集合zset从使用到原理分析》Redis有序集合(zset)是字符串与分值的有序映射,通过跳跃表和哈希表结合实现高效有序性管理,适用于排行榜、延迟队列等场景,其时间复杂度低,内存占... 目录开篇:排行榜背后的秘密一、zset的基本使用1.1 常用命令1.2 Java客户端示例二、zse

Redis中的AOF原理及分析

《Redis中的AOF原理及分析》Redis的AOF通过记录所有写操作命令实现持久化,支持always/everysec/no三种同步策略,重写机制优化文件体积,与RDB结合可平衡数据安全与恢复效率... 目录开篇:从日记本到AOF一、AOF的基本执行流程1. 命令执行与记录2. AOF重写机制二、AOF的

idea+spring boot创建项目的搭建全过程

《idea+springboot创建项目的搭建全过程》SpringBoot是Spring社区发布的一个开源项目,旨在帮助开发者快速并且更简单的构建项目,:本文主要介绍idea+springb... 目录一.idea四种搭建方式1.Javaidea命名规范2JavaWebTomcat的安装一.明确tomcat

Linux命令rm如何删除名字以“-”开头的文件

《Linux命令rm如何删除名字以“-”开头的文件》Linux中,命令的解析机制非常灵活,它会根据命令的开头字符来判断是否需要执行命令选项,对于文件操作命令(如rm、ls等),系统默认会将命令开头的某... 目录先搞懂:为啥“-”开头的文件删不掉?两种超简单的删除方法(小白也能学会)方法1:用“--”分隔命

MyBatis Plus大数据量查询慢原因分析及解决

《MyBatisPlus大数据量查询慢原因分析及解决》大数据量查询慢常因全表扫描、分页不当、索引缺失、内存占用高及ORM开销,优化措施包括分页查询、流式读取、SQL优化、批处理、多数据源、结果集二次... 目录大数据量查询慢的常见原因优化方案高级方案配置调优监控与诊断总结大数据量查询慢的常见原因MyBAT

C#自动化实现检测并删除PDF文件中的空白页面

《C#自动化实现检测并删除PDF文件中的空白页面》PDF文档在日常工作和生活中扮演着重要的角色,本文将深入探讨如何使用C#编程语言,结合强大的PDF处理库,自动化地检测并删除PDF文件中的空白页面,感... 目录理解PDF空白页的定义与挑战引入Spire.PDF for .NET库核心实现:检测并删除空白页