【C语言零基础入门篇 - 14】:顺序表

news2024/9/25 2:21:34

文章目录

  • 顺序表
    • 线性表简介
    • 顺序表的基本概念
    • 顺序表的定义
    • 顺序表的功能实现

顺序表


线性表简介

线性表:线性表是数据结构的一种。
一个线性表是 n 个具有相同特性的数据元素的有限序列。(数组也是线性表)
线性表中数据元素之间是一对一的关系。

线性表主要有顺序表、链表以及栈和队列。

顺序表的基本概念

什么是顺序表?
顺序表是一种数据结构,结构是将数据依次存放在地址连续的存储单元中。

顺序表的存储特点是:
1、存储元素的地址是连续的
2、通过对首地址的偏移,可访问所有元素

顺序表的定义

顺序表的结构定义(数组):

int arr[100] ;	//可以存放100个元素的顺序表
int len = 0 ;		//当前元素的个数
int maxSize = 100 ;		//最多能存多少个元素

顺序表的结构定义(指针):

int *buff = NULL ;	//顺序表
int len = 0 ; //元素个数
int maxSize = 0 ; //最大容量

顺序表的结构定义(结构体):

typedef int Type //类型的定义
struct Array{
	Type *data;	//数据域(存储数据的空间)
	int length; //顺序表的长度
};

顺序表的功能实现

顺序表的基本操作:增、删、改、查。
用指针实现以下顺序表的基本操作:

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#define _CRT_SECURE_NO_WARNINGS

//分配内存空间
void fun(int**p, int*maxSize) // p=&buff;*p=buff
{
	printf("请输入内存空间大小:");
	scanf("%d", maxSize);
	*p = (int*)malloc(*maxSize*sizeof(int));
	//给分配的内存空间赋初值
	memset(*p, 0, *maxSize*sizeof(int)); //逐字节初始化
}

//添加数据
void Add_data(int**p, int*maxSize, int*len)
{
	int data = 0;
	printf("请输入添加的数据:");
	scanf("%d", &data);

	if (*len >= *maxSize) //如果数据量超过最大内存空间
	{
		*maxSize = *maxSize + *maxSize / 2;
		int*temp = (int*)malloc(*maxSize*sizeof(int)); //申请更大的内存空间
		//将数据复制到临时指针变量
		for (int j = 0; j < *len; j++)
		{
			temp[j] = (*p)[j];
		}
		free(*p); //释放buff的内存空间
		*p = temp; //将buff指向temp
	}
	(*p)[*len] = data;
	(*len)++; //因为* 和 +的优先级都是二级,从右往左进行运算
}

//打印结果
void printData(int**p, int len)
{
	for (int i = 0; i < len; i++)
	{
		printf("%d\t", (*p)[i]);
	}
	printf("\n");
}

//删除数据
void deleteData(int**p, int*len)
{
	int data = 0;
	printf("请输入要删除的数据:");
	scanf("%d", &data);

	for (int i = 0; i < *len; i++)
	{
		if ((*p)[i] == data) //如果找到要删除的数据
		{
			for (int j = i; j < *len; j++)
			{
				(*p)[j] = (*p)[j + 1];
			}
			(*len)--; //数据长度减一
			printf("删除 %d 成功,位置:%d\n", data, i+1);
			return; //退出函数
		}
	}
	printf("不存在 %d!\n", data); //没找到要删除的数据
}

//修改数据
void modifyData(int**p, int len)
{
	int data = 0;
	int val = 0;
	printf("请输入要修改的数据:");
	scanf("%d", &data);
	printf("请输入修改后的值:");
	scanf("%d", &val);

	for (int j = 0; j < len; j++)
	{
		if ((*p)[j] == data) //如果找到该数据
		{
			(*p)[j] = val; //修改数据
			printf("数据 %d 已被修改,位置:%d\n", data, j+1);
			return; //退出函数
		}
	}
	printf("未找到该数据!\n"); //如果找不到该数据
}

//查找数据
void findData(int*p, int len) //p = buff
{
	int data = 0;
	printf("请输入查找的数据:");
	scanf("%d", &data);

	for (int j = 0; j < len; j++)
	{
		if (p[j] == data) //找到数据
		{
			printf("元素值:%d,位置:%d\n", data, j + 1);
			return;
		}
	}
	printf("未找到该数据!\n");
}

int main()
{
	int *buff = NULL; //定义一个指针
	int len = 0; //长度
	int maxSize = 0; //最大内存
	int data = 0;
	fun(&buff, &maxSize);

	Add_data(&buff, &maxSize, &len);
	Add_data(&buff, &maxSize, &len);
	Add_data(&buff, &maxSize, &len);

	printData(&buff, len);

	deleteData(&buff, &len);
	printData(&buff, len);
	deleteData(&buff, &len);
	printData(&buff, len);

	modifyData(&buff, len);
	printData(&buff, len);

	findData(buff, len);
	findData(buff, len);
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

打造你的专属主题-VitePress保姆级教程

本篇为vitepress系列教程&#xff0c;在开始前&#xff0c;若还不了解vitepress的小伙伴可以看一下以往文章&#xff1a; 不敲一行代码&#xff01;助你快速搭建属于自己的官网博客&#xff01;-VitePress保姆级教程 文章目录 VitePress主题配置准备自定义主题配置标题配置图标…

如何用AI实现自动更新文章?(全自动更新网站)

AI的诞生确实给我们的生活和工作都带来了很大的改变&#xff0c;从我自身来讲&#xff0c;也渐渐习惯了遇到事情先问问AI&#xff0c;不管是翻译、专业性问题、PPT制作、总结写作这些&#xff0c;确实帮我迅速理清了思路&#xff0c;也可以有很多内容的借鉴。 作为一个业余爱好…

滑动窗口算法第一弹(长度最小的子数组,无重复字符的最长子串 最大连续1的个数III)

目录 前言 1. 长度最小的子数组 &#xff08;1&#xff09;题目及示例 &#xff08;2&#xff09;暴力解法 &#xff08;3&#xff09;优化 2. 无重复字符的最长子串 &#xff08;1&#xff09;题目及示例 &#xff08;2&#xff09;暴力解法 &#xff08;3&#xff…

深度学习:卷积神经网络CNN

目录 一、什么是卷积&#xff1f; 二、卷积神经网络的组成 1. 卷积层 2. 池化层 3. 激活函数 4. 全连接层 三、卷积神经网络的构造 四、代码实现 1.数据预处理 2.创建卷积神经网络 3.创建训练集和测试集函数 4.创建损失函数和优化器并进行训练 一、什么是卷积&…

Kivy,一个上天入地的 Python 库

大家好&#xff01;我是炒青椒不放辣&#xff0c;关注我&#xff0c;收看每期的编程干货。 一个简单的库&#xff0c;也许能够开启我们的智慧之门&#xff0c; 一个普通的方法&#xff0c;也许能在危急时刻挽救我们于水深火热&#xff0c; 一个新颖的思维方式&#xff0c;也许能…

USB 电缆中的信号线 DP、DM 的缩写由来

经常在一些芯片的规格书中看到 USB 的信号对是以 DP 和 DM 命名&#xff1a; 我在想&#xff0c;这些规格书是不是写错了&#xff0c;把 N 写成 M 了&#xff1f;DM 中的 M 到底是什么的缩写&#xff1f; 于是我找了一些资料&#xff0c;终于在《Universal Serial Bus Cables …

string 的介绍及使用

一.string类介绍 C语言中&#xff0c;字符串是以’\0’结尾的一些字符的集合&#xff0c;为了操作方便&#xff0c;C标准库中提供了一些str系列的库函数&#xff0c;但是这些库函数与字符串是分离开的&#xff0c;不太符合OOP的思想&#xff0c;而且底层空间需要用户自己管理&a…

BUUCTF [SCTF2019]电单车详解两种方法(python实现绝对原创)

使用audacity打开&#xff0c;发现是一段PT2242 信号 PT2242信号 有长有短&#xff0c;短的为0&#xff0c;长的为1化出来 这应该是截获电动车钥匙发射出的锁车信号 0 01110100101010100110 0010 0前四位为同步码0 。。。中间这20位为01110100101010100110为地址码0010为功…

ssm病人跟踪治疗信息管理系统

专业团队&#xff0c;咨询就送开题报告&#xff0c;欢迎大家咨询留言 摘 要 病人跟踪治疗信息管理系统采用B/S模式&#xff0c;促进了病人跟踪治疗信息管理系统的安全、快捷、高效的发展。传统的管理模式还处于手工处理阶段&#xff0c;管理效率极低&#xff0c;随着病人的不断…

《SG-Former: Self-guided Transformer with Evolving Token Reallocation》ICCV2023

摘要 SG-Former&#xff08;Self-guided Transformer&#xff09;是一种新型的视觉Transformer模型&#xff0c;旨在解决传统Transformer在处理大型特征图时面临的计算成本高的问题。该模型通过一种自适应细粒度的全局自注意力机制&#xff0c;实现了有效的计算成本降低。它利…

VmWare安装虚拟机教程(centos7)

VMWare下载&#xff1a; 下载 VMware Workstation Pro - VMware Customer Connect 安装包&#xff1a;&#xff08;16的版本&#xff09;免费&#xff01;&#xff08;一个赞就行&#xff09; 一直点下一步即可&#xff0c;注意修改一下安装位置就好 二、安装虚拟机 安装虚…

鸭脖变“刺客”,啃不起了

撰文&#xff5c;ANGELICA 编辑&#xff5c;ANGELICA 审核&#xff5c;烨 Lydia 声明&#xff5c;图片来源网络。日晞研究所原创文章&#xff0c;如需转载请留言申请开白。 你有多久没吃卤味了&#xff1f; 2020年之后&#xff0c;人们对于几大卤味巨头的关注度正在下降。 …

视频字幕生成:分享6款专业易操作的工具,让创作更简单!

​视频字幕如何添加&#xff1f;日常剪辑Vlog视频时&#xff0c;就需要给视频添加上字幕了。字幕是一个比较重要的元素&#xff0c;它不仅可以帮助听力受损或语言障碍的人士理解内容&#xff0c;还可以让你的视频更加易于理解和吸引观众。 那么如何实现视频字幕生成&#xff0c…

【LLaMa2入门】从零开始训练LLaMa2

目录 1 背景2 搭建环境2.1 硬件配置2.2 搭建虚拟环境2.2.1 创建虚拟环境2.2.2 安装所需的库 3 准备工作3.1 下载GitHub代码3.2 下载模型3.3 数据处理3.3.1 下载数据3.3.2 数据集tokenize预处理 4 训练4.1 修改配置4.2 开始训练4.3 多机多卡训练 5 模型推理5.1 编译5.1.1 安装gc…

ResNet18模型扑克牌图片预测

加入会员社群&#xff0c;免费获取本项目数据集和代码&#xff1a;点击进入>> 1. 项目简介 该项目旨在通过深度学习技术&#xff0c;使用ResNet18模型对扑克牌图像进行预测与分类。扑克牌图片分类任务属于图像识别中的一个应用场景&#xff0c;要求模型能够准确识别扑克…

【python篇】python pickle模块一篇就能明白,快速理解

持久性就是指保持对象&#xff0c;甚至在多次执行同一程序之间也保持对象。通过本文&#xff0c;您会对 Python对象的各种持久性机制&#xff08;从关系数据库到 Python 的 pickle以及其它机制&#xff09;有一个总体认识。另外&#xff0c;还会让您更深一步地了解Python 的对象…

音视频入门基础:FLV专题(5)——FFmpeg源码中,判断某文件是否为FLV文件的实现

一、引言 通过FFmpeg命令&#xff1a; ./ffmpeg -i XXX.flv 可以判断出某个文件是否为FLV文件&#xff1a; 所以FFmpeg是怎样判断出某个文件是否为FLV文件呢&#xff1f;它内部其实是通过flv_probe函数来判断的。从《FFmpeg源码&#xff1a;av_probe_input_format3函数和AVI…

Serilog文档翻译系列(五) - 编写日志事件

日志事件通过 Log 静态类或 ILogger 接口上的方法写入接收器。下面的示例将使用 Log 以便语法简洁&#xff0c;但下面显示的方法同样可用于接口。 Log.Warning("Disk quota {Quota} MB exceeded by {User}", quota, user); 通过此日志方法创建的警告事件将具有两个相…

mes系统在中小企业智能制造作用

MES系统&#xff08;制造执行系统&#xff09;在中小企业智能制造中扮演着至关重要的角色&#xff0c;其作用主要体现在以下几个方面&#xff1a; 1. 提升生产效率与质量 实时监控与数据采集&#xff1a;MES系统能够实时采集生产现场的各项数据&#xff0c;如设备状态、生产进…

nmap 命令:网络扫描

一、命令简介 ​nmap​&#xff08;Network Mapper&#xff09;是一个开放源代码的网络探测和安全审核的工具。它最初由Fyodor Vaskovich开发&#xff0c;用于快速地扫描大型网络&#xff0c;尽管它同样适用于单个主机。 ​nmap​的功能包括&#xff1a; 发现主机上的开放端…