数据结构顺序表

思维导图

练习

头文件

  1 #ifndef __HEAD_H__
  2 #define __HEAD_H__
  3 
  4 
  5 #include <stdio.h>
  6 #include <string.h>
  7 #include <stdlib.h>
  8 
  9 
 10 #define MAXSIZE 7
 11 typedef int datatype;
 12 enum
 13 {
 14     FLASE=-1,
 15     SUCCESS
 16 };
 17 //定义顺序表:数据元素和顺序表长度
 18 typedef struct SQLIST
 19 {
 20     //数据元素                                                                                                                 
 21     datatype data[MAXSIZE];
 22     //顺序表长度
 23     int len;
 24 }sqlist;
 25 
 26 sqlist* create();
 27 int full(sqlist *list);
 28 int insert_rear(datatype element,sqlist *list);
 29 int output(sqlist *list);
 30 int delete_rear(sqlist *list);
 31 
 32 void search_index(sqlist*list,int index);
 33 void change_search_index(sqlist*list,int index,int element);
 34 void insert_index(sqlist*list,int index,int element);
 35 void delete_index(sqlist*list,int index);
 36 int search_key(sqlist*list,int element);
 37 void delete_same(sqlist*list);
 38 void change_key(sqlist*list,int key,int element);
 39 void delete_key(sqlist*list,int key);
 40 void bubble(sqlist*list);
 41 sqlist* free_space(sqlist*list);
 42 #endif

自定义函数

  1 #include "head.h"
  2 
  3 
  4 
  5 /*
  6  * function:    创建顺序表在堆区
  7  * @param [ in] 
  8  * @param [out] 
  9  * @return      成功返回地址,失败返回NULL
 10  */
 11 
 12 
 13 sqlist* create()
 14 {
 15     sqlist *list=(sqlist*)malloc(sizeof(sqlist));
 16     if(NULL==list)
 17         return NULL;
 18     //成功返回堆区
 19     //对数据元素清零
 20     memset(list->data,0,sizeof(list->data));
 21     //顺序长度清零                                                                                                             
 22     list->len=0;
 23     return list;
 24 }
 25 
 26 
 27 
 28 /*
 29  * function:    判断是否为满
 30  * @param [ in] 
 31  * @param [out] 
 32  * @return      
 33  */
 34 int full(sqlist *list)
 35 {
 36     return list->len==MAXSIZE?FLASE:SUCCESS;
 37 }
 38 
 39 
 40 /*
 41  * function:    尾插入
 42  * @param [ in] 
 43  * @param [out] 
 44  * @return      
 45  */
 46 
 47 int insert_rear(datatype element,sqlist *list)
 48 {
 49     if(NULL==list ||full(list))
 50         return FLASE;
 51     list->data[list->len++]=element;
 52     return SUCCESS;
 53 }
 54 /*
 55  * function:    判空
 56  * @param [ in] 
 57  * @param [out] 
 58  * @return      
 59  */
 60 int empty(sqlist *list)
 61 {
 62     return list->len==0?FLASE:SUCCESS;
 63 }
 64 
 65 
 66 
 67 
 68 /*                                                                                                                             
 69  * function:        遍历
 70  * @param [ in] 
 71  * @param [out] 
 72  * @return      成功返回0,失败返回-1
 73  */
 74 
 75 
 76 int output(sqlist *list)
 77 {
 78     //判断顺序表是否创建成功
 79     //判断顺序表是否为空
 80     if(NULL==list || empty(list))
 81         return FLASE;
 82     //循环遍历
 83     for(int i=0;i<list->len;i++)
 84     {
 85         printf("%-5d",list->data[i]);
 86 
 87     }
 88     puts("");
 89 
 90 }
 91 
 92 /*
 93  * function:    尾删
 94  * @param [ in] 
 95  * @param [out] 
 96  * @return      
 97  */
 98 
 99 
100 int delete_rear(sqlist *list)
101 {
102     //1.判断顺序表是否创建成功
103     //2.判断顺序表是否为空
104     if(NULL==list || empty(list))
105         return FLASE;
106     //3.删除
107     list->len--;
108     return SUCCESS;
109 }
110 
111 
112 /*
113  * function:    按下表查找
114  * @param [ in] 
115  * @param [out] 
116  * @return      
117  */
118 void search_index(sqlist*list,int index)
119 {
120     if(NULL==list||empty(list)||index<0||index>=list->len)
121         return;
122     printf("element searched by search index is %d\n",list->data[index]);
123 
124 }
125     
126 /*
127  * function:    按下表修改
128  * @param [ in] 
129  * @param [out] 
130  * @return      
131  */
132 void change_search_index(sqlist*list,int index,int element)
133 {
134     if(NULL==list||empty(list)||index<0||index>=list->len)
135         return;
136     list->data[index]=element;
137 }
138 /*
139  * function:    按下表插入
140  * @param [ in] 
141  * @param [out] 
142  * @return      
143  */
144 void insert_index(sqlist*list,int index,int element)
145 {
146     if(NULL==list||full(list)||index<0||index>list->len)
147         return;
148     for(int i=list->len-1;i>=index;i--)
149     {
150         list->data[i+1]=list->data[i];
151     }
152     list->data[index]=element;
153     list->len++;
154 }
155 
156 /*
157  * function:    按下表删除
158  * @param [ in] 
159  * @param [out] 
160  * @return      
161  */
162 void delete_index(sqlist*list,int index)
163 {
164     if(NULL==list||empty(list)||index<0||index>=list->len)
165         return;
166     for(int i=index+1;i<list->len;i++)
167     {
168         list->data[i-1]=list->data[i];
169     }
170     list->len--;
171 }
172 
173 /*
174  * function:    按元素查找
175  * @param [ in] 
176  * @param [out] 
177  * @return      
178  */
179 int search_key(sqlist*list,int element)
180 {
181     if(NULL==list||empty(list))
182         return FLASE;
183     for(int i=0;i<list->len;i++)
184     {
185         if(element==list->data[i])
186             return i;
187     }
188     return FLASE;
189 }
190 
191 
192 /*
193  * function:    按元素去重
194  * @param [ in] 
195  * @param [out] 
196  * @return      
197  */
198 void delete_same(sqlist*list)
199 {
200     for(int i=0;i<list->len-1;i++)
201     {
202         for(int j=i+1;j<list->len;j++)
203         {
204             if(list->data[i]==list->data[j])
205             {
206                 delete_index(list,j);
207                 j--;
208             }
209         }
210     }
211 }
212 
213 /*
214  * function:    按任意元素修改
215  * @param [ in] 
216  * @param [out] 
217  * @return      
218  */
219 void change_key(sqlist*list,int key,int element)
220 {
221 
222     int index=search_key(list,key);
223     change_search_index(list,index,element);
224 }
225 
226 
227 
228 /*
229  * function:    按任意元素删除
230  * @param [ in] 
231  * @param [out] 
232  * @return      
233  */
234 void delete_key(sqlist*list,int key)
235 {
236     int index=search_key(list,key);
237     delete_index(list,index);                                                                                                  
238 }
239 
240 /*
241  * function:    顺序表排序
242  * @param [ in] 
243  * @param [out] 
244  * @return      
245  */
246 void bubble(sqlist*list)
247 {
248     for(int i=0;i<list->len-1;i++)
249     {
250         for(int j=0;j<list->len-i;j++)
251         {
252             if(list->data[j]<list->data[j+1])
253             {
254                 int temp=list->data[j];
255                 list->data[j]=list->data[j+1];
256                 list->data[j+1]=temp;
257             }
258         }
259     }
260 }
261 
262 
263 
264 /*
265  * function:    顺序表释放空间
266  * @param [ in] 
267  * @param [out] 
268  * @return      
269  */
270 sqlist* free_space(sqlist*list)
271 {
272     if(NULL==list)
273         return NULL;
274     free(list);
275     list=NULL;
276     return NULL;
277 }

主函数

  1 #include "head1.h"
  2 int main(int argc, const char *argv[])
  3 {
  4     //创建顺序表在堆区
  5     sqlist *list=create();
  6 
  7 
  8     //循环尾插
  9     int n;
 10     datatype element;
 11     printf("请输入长度");
 12     scanf("%d",&n);
 13     for(int i=0;i<n;i++)
 14     {
 15         printf("请输入尾插入的值");
 16         scanf("%d",&element);
 17         int flag=insert_rear(element,list);
 18         if(flag==FLASE)
 19         {
 20             puts("NULL or FULL");
 21             break;
 22         }
 23     }
 24     //循环遍历                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               
 25     output(list);
 26 
 27 
 28     //尾删
 29     delete_rear(list);
 30     printf("尾删后\n");
 31     output(list);
 32 
 33 
 34 
 35 
 36     //按下表查找
 37     int index;
 38 
 39 
 40     //输入要查找的下表
 41     printf("please enter search index:");
 42     scanf("%d",&index);
 43     //输出查找下表的值
 44     printf("下表查找的值\n");
 45     search_index(list,index);
 46 
 47 
 48 
 49 
 50     //任意下表修改
 51     //输入修改下表
 52     printf("please enter change index:");
 53     scanf("%d",&index);
 54     //输入要修改的值
 55     printf("please enter change element:");
 56     scanf("%d",&element);
 57     change_search_index(list,index,element);
 58     //输出修改后的结果
 59     printf("按任意下表修改后:\n");
 60     output(list);
 61     puts("");
 62 
 63     //按下表插入
 64     //输入要插入的下表
 65     printf("please enter insert index:");
 66     scanf("%d",&index);
 67     //输入要插入的值
 68     printf("please enter insert element:");
 69     scanf("%d",&element);
 70     insert_index(list,index,element);
 71     //插入后的结果
 72     printf("按下表插入后\n");
 73     output(list);
 74     puts("");
 75 
 76 
 77 
 78     //按下表删除
 79     //输入要删除的下表
 80     printf("please enter delete index:");
 81     scanf("%d",&index);
 82     delete_index(list,index);
 83     //删除后的结果
 84     printf("按下表删除后\n");
 85     output(list);
 86     puts("");
 87 
 88 
 89     //按元素查找
 90     printf("please enter search element:");
 91     scanf("%d",&element);
 92     int flag=search_key(list,element);
 93     printf("查找的元素的下表为:");
 94     if(flag==-1)
 95         puts("error");
 96     else
 97         printf("%d\n",flag);
 98     puts("");
 99 
100     //按元素去重
101     delete_same(list);
102     printf("按元素去重后\n");
103     output(list);
104     puts("");
105 
106 
107     int key;
108 
109     //按任意元素修改
110     printf("please enter change key:");
111     scanf("%d",&key);
112     printf("please enter change element:");
113     scanf("%d",&element);
114     change_key(list,key,element);
115     printf("按任意下表修改后\n");
116     output(list);
117     puts("");
118 
119 
120     //按任意元素删除
121     printf("please enter delete key:");
122     scanf("%d",&key);
123     delete_key(list,key);
124     printf("按任意元素删除后\n");
125     output(list);
126     puts("");
127 
128 
129     //冒泡排序顺序表
130     bubble(list);
131     printf("排序后\n");
132     output(list);
133     puts("");
134 
135     //顺序表释放空间
136     list=free_space(list);
137     return 0;
138 }

效果图

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/343660.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

在Vite5.x中使用monaco-editor

Uncaught (in promise) Error: Unexpected usage at _EditorSimpleWorker.loadForeignModule 如果你像我这样报错,那一般是getWorker部分出问题了. 首先推个帖子: https://github.com/vitejs/vite/discussions/1791 然后是代码 不需要在vite.config.ts中做任何设置,也不用…

RabbitMQ 入门到精通

RabbitMQ入门到精通 一、了解RabbitMQ1.基础知识2.多种交换机模型详解 二、服务端搭建1.简单搭建2.信息持久化到容器外部 三、消息生产者和消费者1.消息生产者2.消息消费者3.RabbitTemplate 详解4.RabbitListener详解5.其他注解 四、如何保证消息可靠性1.发送方进行消息发送成功…

[笔记]Spring AOP

Spring AOP&#xff08;Aspect Oriented Programming&#xff09; AOP将应用程序分为核心业务和非核心的公共功能&#xff0c;AOP的关注点是系统中的非核心的公共功能&#xff1b; AOP可以通过预编译或者运行期动态代理的方式&#xff0c;为横跨多个对象&#xff08;没有继承关…

Elasticsearch:Simulate ingest API

Ingest pipeline 为我们摄入数据提供了极大的方便。在我之前的文章中&#xff0c;有非常多的有关 ingest pipeline 的文章。请详细阅读文章 “Elastic&#xff1a;开发者上手指南”。针对一组提供的文档执行摄取管道&#xff0c;可以选择使用替代管道定义。 Simulate ingest AP…

Parallels Desktop 19 mac 虚拟机软件 兼容M1 M2

Parallels Desktop 19 for Mac 是一款适用于 macOS 的虚拟机软件。无需重启即可在 Mac 上运行 Windows、Linux 等系统&#xff0c;具有速度快、操作简单且功能强大的优点。包括 30 余种实用工具&#xff0c;可简化 Mac 和 Windows 上的日常任务。 软件下载&#xff1a;Parallel…

小新22-IAP,24-IAP,27-IAP(F0GG,F0GH,F0GJ)原厂Win11.22H2系统

lenovo联想小新22寸,24寸,27寸IAP原装出厂Windows11系统镜像还原包&#xff0c;恢复出厂开箱状态 适用型号&#xff1a; 联想小新27-IAP(F0GJ),小新24-IAP(F0GH),小新22-IAP(F0GG) IdeaCentre AIO 3 22IAP7,IdeaCentre AIO 3 24IAP7,IdeaCentre AIO 3 27IAP7 链接&#xff1…

【DevOps】Jenkins Extended E-mail 邮件模板添加自定义变量

文章目录 1、配置Jenkins邮箱2、配置告警模板1、配置Jenkins邮箱 略 2、配置告警模板 自定义变量:DYSK_PYTEST_STATUS // Uses Declarative syntax to run commands inside a container. pipeline {agent {kubernetes {cloud "kubernetes" //选择名字是kuberne…

关于网络模型的笔记

1. OSI 七层参考模型&#xff1a; 简介&#xff1a; 七层模型&#xff0c;亦称 OSI&#xff08;Open System Interconnection&#xff09;参考模型&#xff0c;即开放式系统互联。参考模型 是国际标准化组织&#xff08;ISO&#xff09;制定的一个用于计算机或通信系统间互联…

解决docker desktop 登录不上账号的问题

一、背景 点击“Sign in”&#xff0c;一直卡在Verifying credentials...&#xff0c;重试也没用。 二、解决办法 1、macOS下载并安装Proxifier 2、配置Proxifier 配置Proxies 配置rule 其中的Applications填&#xff1a;"Docker.app"; "Docker"; com.…

【极数系列】Flink环境搭建(02)

【极数系列】Flink环境搭建&#xff08;02&#xff09; 引言 1.linux 直接在linux上使用jdk11flink1.18.0版本部署 2.docker 使用容器部署比较方便&#xff0c;一键启动停止&#xff0c;方便参数调整 3.windows 搭建Flink 1.18.0版本需要使用Cygwin或wsl工具模拟unix环境…

web安全学习笔记【07】——非http\https抓包

#知识点&#xff1a; 1、Web常规-系统&中间件&数据库&源码等 2、Web其他-前后端&软件&Docker&分配站等 3、Web拓展-CDN&WAF&OSS&反向&负载均衡等 ----------------------------------- 1、APP架构-封装&原生态&H5&flutter…

网络协议与攻击模拟_07UDP协议

一、简单概念 1、UDP协议简介 UDP&#xff08;用户数据报&#xff09;协议&#xff0c;是传输层的协议。不需要建立连接&#xff0c;直接发送数据&#xff0c;不会重新排序&#xff0c;不需要确认。 2、UDP报文字段 源端口目的端口UDP长度UDP校验和 3、常见的UDP端口号 5…

智能GPT图书管理系统(SpringBoot2+Vue2)、接入GPT接口,支持AI智能图书馆

☀️技术栈介绍 ☃️前端主要技术栈 技术作用版本Vue提供前端交互2.6.14Vue-Router路由式编程导航3.5.1Element-UI模块组件库&#xff0c;绘制界面2.4.5Axios发送ajax请求给后端请求数据1.2.1core-js兼容性更强&#xff0c;浏览器适配3.8.3swiper轮播图插件&#xff08;快速实…

LiveGBS流媒体平台GB/T28181常见问题-如何配置使用自己已有的redis服务替换redis版本升级redis版本

LiveGBS如何配置使用自己已有的redis服务替换redis版本升级redis版本 1、Redis服务2、如何切换REDIS?2.1、停止启动REDIS2.2、配置信令服务2.3、配置流媒体服务2.4、启动 3、搭建GB28181视频直播平台 1、Redis服务 在LivGBS中Redis作为数据交换、数据订阅、数据发布的高速缓存…

Redis(七)复制

文章目录 是什么功能配置配主库不配从库权限细节 案例配置文件修改 一主二仆固定配置文件主从问题命令操作手动指定 薪火相传反客为主复制原理和工作流程存在问题 是什么 https://redis.io/docs/management/replication/ 就是主从复制&#xff0c;master以写为主&#xff0c;S…

Vue中的常用指令

Vue中的常用指令 概念&#xff1a;指令&#xff08;Directives&#xff09;是 Vue 提供的带有 v- 前缀 的特殊标签属性。 为啥要学&#xff1a;提高程序员操作 DOM 的效率。 vue 中的指令按照不同的用途可以分为如下 6 大类&#xff1a; 内容渲染指令&#xff08;v-html、v…

【制作100个unity游戏之23】实现类似七日杀、森林一样的生存游戏2(附项目源码)

本节最终效果演示 文章目录 本节最终效果演示系列目录前言添加小动物模型动画动物AI脚本效果 添加石头石头模型拾取物品效果 源码完结 系列目录 【制作100个unity游戏之23】实现类似七日杀、森林一样的生存游戏1&#xff08;附项目源码&#xff09; 【制作100个unity游戏之23】…

Mac Idea安装后无法启动

1、起因 想安装一个新版的idea2023.3.2&#xff0c;结果安装完之后直接无法启动 以为是卸载不干净&#xff0c;下载了一个腾讯柠檬&#xff0c;结果将2018版也一并卸载了 好家伙&#xff0c;彻底没得用 2、找原因 1&#xff09;查看idea报错信息 网上找了一圈&#xff0c;其…

burp靶场--host攻击

burp靶场–host攻击 https://portswigger.net/web-security/host-header#what-is-an-http-host-header-attack 在本节中&#xff0c;我们将讨论错误配置和有缺陷的业务逻辑如何通过 HTTP 主机标头使网站遭受各种攻击。我们将概述用于识别易受 HTTP 主机标头攻击的网站的高级方…

RabbitMQ中交换机的应用及原理,案例的实现

目录 一、介绍 1. 概述 2. 作用及优势 3. 工作原理 二、交换机Exchange 1. Direct 2. Topic 3. Fanout 三、代码案例 消费者代码 1. 直连direct 生产者代码 测试 2. 主题topic 生产者代码 测试 3. 扇形fanout 生产者代码 测试 每篇一获 一、介绍 1. …