当前位置: 首页 > news >正文

数据结构与算法学习笔记六--数组和广义表(C语言)

目录

前言

1.数组

1.定义

2.初始化

3.销毁

4.取值

5.设置值

6.完整代码


前言

        这篇博客主要介绍数据结构中的数组和广义表的用法。

1.数组

        在数据结构中,数组是一种线性数据结构,它由一组连续的相同类型的元素组成,每个元素都有一个唯一的索引或者下标来标识其在数组中的位置。

        数字的常用操作除了初始化和销毁之外,只有存取元素和修改元素值的操作。

1.定义

        我们一般使用顺序结构来定义数组。

#define MAX_ARRAY_DIM 8 // 设置数组维数的最大值为8
typedef struct {int *base;      // 数组元素基址,由initArray分配int dim;        // 数组维数int *bounds;    // 数组维界基址,由initArray分配int *constants; // 数组影像函数常量基址,由initArray分配
} Array;

2.初始化

//初始化
int initArray(Array *array, int dim, ...) {if (dim < 1 || dim > MAX_ARRAY_DIM) return 0;array->dim = dim;array->bounds = (int *)malloc(dim * sizeof(int));if (!array->bounds) return 0;int total = 1;va_list ap;va_start(ap, dim);for (int i = 0; i < dim; ++i) {array->bounds[i] = va_arg(ap, int);if (array->bounds[i] < 0) return 0;total *= array->bounds[i];}va_end(ap);array->base = (int *)malloc(total * sizeof(int));if (!array->base) return 0;array->constants = (int *)malloc(dim * sizeof(int));if (!array->constants) return 0;array->constants[dim - 1] = 1;for (int i = dim - 2; i >= 0; --i)array->constants[i] = array->bounds[i + 1] * array->constants[i + 1];return 1;
}

3.销毁

int destroyArray(Array *array) {if (!array->base) return 0;free(array->base);array->base = NULL;if (!array->bounds) return 0;free(array->bounds);array->bounds = NULL;if (!array->constants) return 0;free(array->constants);array->constants = NULL;return 1;
}

4.取值

int getValue(Array *array, ...) {va_list ap;va_start(ap, array);int index = 0;for (int i = 0; i < array->dim; ++i) {int subscript = va_arg(ap, int);if (subscript < 0 || subscript >= array->bounds[i]) {va_end(ap);return 0;}index += array->constants[i] * subscript;}va_end(ap);return array->base[index];
}

5.设置值

int setValue(Array *array, int value, ...) {va_list ap;va_start(ap, value);int index = 0;for (int i = 0; i < array->dim; ++i) {int subscript = va_arg(ap, int);if (subscript < 0 || subscript >= array->bounds[i]) {va_end(ap);return 0;}index += array->constants[i] * subscript;}va_end(ap);array->base[index] = value;return 1;
}

6.完整代码

#include <stdio.h>
#include <stdarg.h>
#include <stdlib.h>#define MAX_ARRAY_DIM 8 // 设置数组维数的最大值为8
typedef struct {int *base;      // 数组元素基址,由initArray分配int dim;        // 数组维数int *bounds;    // 数组维界基址,由initArray分配int *constants; // 数组影像函数常量基址,由initArray分配
} Array;// 基本操作的函数原型说明
int initArray(Array *array, int dim, ...);
int destroyArray(Array *array);
int getValue(Array *array, ...);
int setValue(Array *array, int value, ...);
void testArrayOperations(void);//初始化
int initArray(Array *array, int dim, ...) {if (dim < 1 || dim > MAX_ARRAY_DIM) return 0;array->dim = dim;array->bounds = (int *)malloc(dim * sizeof(int));if (!array->bounds) return 0;int total = 1;va_list ap;va_start(ap, dim);for (int i = 0; i < dim; ++i) {array->bounds[i] = va_arg(ap, int);if (array->bounds[i] < 0) return 0;total *= array->bounds[i];}va_end(ap);array->base = (int *)malloc(total * sizeof(int));if (!array->base) return 0;array->constants = (int *)malloc(dim * sizeof(int));if (!array->constants) return 0;array->constants[dim - 1] = 1;for (int i = dim - 2; i >= 0; --i)array->constants[i] = array->bounds[i + 1] * array->constants[i + 1];return 1;
}int destroyArray(Array *array) {if (!array->base) return 0;free(array->base);array->base = NULL;if (!array->bounds) return 0;free(array->bounds);array->bounds = NULL;if (!array->constants) return 0;free(array->constants);array->constants = NULL;return 1;
}int getValue(Array *array, ...) {va_list ap;va_start(ap, array);int index = 0;for (int i = 0; i < array->dim; ++i) {int subscript = va_arg(ap, int);if (subscript < 0 || subscript >= array->bounds[i]) {va_end(ap);return 0;}index += array->constants[i] * subscript;}va_end(ap);return array->base[index];
}int setValue(Array *array, int value, ...) {va_list ap;va_start(ap, value);int index = 0;for (int i = 0; i < array->dim; ++i) {int subscript = va_arg(ap, int);if (subscript < 0 || subscript >= array->bounds[i]) {va_end(ap);return 0;}index += array->constants[i] * subscript;}va_end(ap);array->base[index] = value;return 1;
}void testArrayOperations(void) {Array array;if (initArray(&array, 2, 3, 4)) {printf("Array initialized successfully.\n");printf("Setting values...\n");for (int i = 0; i < 3; ++i) {for (int j = 0; j < 4; ++j) {if (setValue(&array, i * 10 + j, i, j)) {printf("Value set at (%d, %d).\n", i, j);} else {printf("Failed to set value at (%d, %d).\n", i, j);}}}printf("Getting values...\n");for (int i = 0; i < 3; ++i) {for (int j = 0; j < 4; ++j) {int value;if (getValue(&array, i, j, &value)) {printf("Value at (%d, %d): %d\n", i, j, value);} else {printf("Failed to get value at (%d, %d).\n", i, j);}}}printf("Destroying array...\n");if (destroyArray(&array)) {printf("Array destroyed successfully.\n");} else {printf("Failed to destroy array.\n");}} else {printf("Failed to initialize array.\n");}
}
int main(int argc, const char *argv[]) {testArrayOperations();return 0;
}

相关文章:

数据结构与算法学习笔记六--数组和广义表(C语言)

目录 前言 1.数组 1.定义 2.初始化 3.销毁 4.取值 5.设置值 6.完整代码 前言 这篇博客主要介绍数据结构中的数组和广义表的用法。 1.数组 在数据结构中&#xff0c;数组是一种线性数据结构&#xff0c;它由一组连续的相同类型的元素组成&#xff0c;每个元素都有一个唯…...

图搜索算法详解

图搜索算法详解 摘要&#xff1a; 图搜索算法是解决路径规划和网络分析问题的关键技术。本文将详细介绍图搜索算法的基本概念、分类以及常见的算法&#xff0c;如广度优先搜索&#xff08;BFS&#xff09;、深度优先搜索&#xff08;DFS&#xff09;、A*搜索等。同时&#xff…...

安卓中常见的UI控件

TextView&#xff08;文本视图&#xff09;EditText&#xff08;编辑文本&#xff09;Button&#xff08;按钮&#xff09;ImageView&#xff08;图像视图&#xff09;ImageButton&#xff08;图像按钮&#xff09;CheckBox&#xff08;复选框&#xff09;RadioButton&#xff…...

基于Labelme的背部穴位关键点制作

一、穴位定位方法 穴位定位&#xff0c;自春秋时期以来&#xff0c;通过各代医学实践的继承与发展&#xff0c;形成了一套较为科学的定位体系。这套体系基于经络理论&#xff0c;采用“寸”作为测量单位&#xff0c;按照人体比例来进行精确的穴位定位&#xff0c;主要有依据体…...

go-mysql-transfer 同步数据到es

同步数据需要注意的事项 前提条件 1 要同步的mysql 表必须包含主键 2 mysql binlog 必须是row 模式 3 不支持程序运行过程中修改表结构 4 要赋予连接mysql 账号的权限 reload, replication super 权限 如果是root 权限则不需要 安装 go-mysql-transfer ​ git clone…...

外包干了3天,技术就明显退步了。。。。。

先说一下自己的情况&#xff0c;本科生&#xff0c;19年通过校招进入广州某软件公司&#xff0c;干了接近4年的功能测试&#xff0c;今年年初&#xff0c;感觉自己不能够在这样下去了&#xff0c;长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了四年的功能测试…...

将要上市的自动驾驶新书《自动驾驶系统开发》中摘录各章片段 1

以下摘录一些章节片段&#xff1a; 1. 概论 自动驾驶系统的认知中有一些模糊的地方&#xff0c;比如自动驾驶系统如何定义的问题&#xff0c;自动驾驶的研发为什么会有那么多的子模块&#xff0c;怎么才算自动驾驶落地等等。本章想先给读者一个概括介绍&#xff0c;了解自动驾…...

String、StringBuilder、StringBuffer之间的区别是什么?

在Java中&#xff0c;String、StringBuilder 和 StringBuffer 是处理字符串的三个类&#xff0c;其中 String 是不可变对象&#xff0c;而 StringBuilder 和 StringBuffer 是可变对象。这些类在字符串操作方面具有不同的特性和用途。 String String 类表示不可变的字符序列&a…...

docker系列8:容器卷挂载(上)

目录 传送门 从安装redis说起 什么是容器卷挂载 操作系统的挂载 日志文件一般是"首恶元凶" 挂载命令 容器卷挂载 卷挂载命令 启动时挂载 查看挂载卷信息 容器卷管理 查看卷列表 创建容器卷 具名挂载与匿名挂载 具名挂载 传送门 docker系列1&#xff…...

痉挛性斜颈患者自己做哪些运动对脖子好?

痉挛性斜颈&#xff08;Dystonia&#xff09;是一种罕见的神经系统疾病&#xff0c;其特点是颈部肌肉痉挛&#xff0c;导致头部姿势异常倾斜或扭曲。而在治疗痉挛性斜颈中&#xff0c;运动疗法是非常重要的一部分。下面将介绍一些痉挛性斜颈患者可以自己进行的运动&#xff0c;…...

数据结构——二叉树链式结构的实现(上)

二叉树概念 再看二叉树基本操作前&#xff0c;再回顾下二叉树的概念&#xff0c; 二叉树是&#xff1a; 1. 空树 2. 非空&#xff1a;根节点&#xff0c;根节点的左子树、根节点的右子树组成的。 从概念中可以看出&#xff0c;二叉树定义是递归式的 二叉树构成&#xff1…...

数据结构内容概览

0. 绪论 绪论01——复杂度度量 绪论02——复杂度分析 绪论03——递归分析 绪论04——算法分析 绪论05——动态规划 算法设计与优化——前n项和计算 算法设计优化——对于任意非负整数&#xff0c;统计其二进制展开中数位1的总数 算法设计优化——Fibonacci数 算法设计优化——…...

当Linux系统运行时间长了之后,会出现磁盘空间不足提示,需要及时进行清理

Linux系统&#xff08;CentOS 7&#xff09;的磁盘空间不足时&#xff0c;可以采取以下步骤进行清理&#xff1a; 查找并删除大文件&#xff1a; 使用du和find命令可以找到并删除大文件。例如&#xff0c;要查找/目录下大于100MB的文件&#xff0c;可以运行&#xff1a; find /…...

【Flask 系统教程 4】Jinjia2模版和语法

Jinjia2 模板 模板的介绍 Jinja2 是一种现代的、设计优雅的模板引擎&#xff0c;它是 Python 的一部分&#xff0c;由 Armin Ronacher 开发。Jinja2 允许你在 HTML 文档中嵌入 Python 代码&#xff0c;以及使用变量、控制结构和过滤器来动态生成内容。它的语法简洁清晰&#…...

与 Apollo 共创生态:七周年大会心得

与 Apollo 共创生态&#xff1a;七周年大会心得 前言 4月19日&#xff0c;百度Apollo迎来七周年&#xff0c;历经七年的不懈追求与创新&#xff0c;Apollo开放平台已陆续推出了13个版本&#xff0c;汇聚了来自全球170多个国家与地区的16万名开发者及220多家合作伙伴。作为一名…...

『FPGA通信接口』DDR(4)DDR3内存条SODIMMs读写测试

文章目录 前言1.MIG IP核配置2.测试程序3.DDR应用4.传送门 前言 不论是DDR3颗粒还是DDR3内存条&#xff0c;xilinx都是通过MIG IP核实现FPGA与DDR的读写。本文区别于DDR颗粒&#xff0c;记录几个与颗粒配置不同的地方。关于DDR的原理与MIG IP的简介&#xff0c;请查看前面文章&…...

Element UI 快速入门指南

Element UI 快速入门指南 Element UI 是一个基于 Vue.js 的组件库&#xff0c;提供了丰富的 UI 组件和工具&#xff0c;可以帮助开发人员快速构建现代化的 Web 应用程序。本文将介绍如何快速入门使用 Element UI&#xff0c;并展示一些常用的组件和功能。 安装 Element UI 使…...

CentOS常用命令有哪些?

目录 一、CentOS常用命令有哪些&#xff1f; 二、不熟悉命令怎么办&#xff1f; 场景一&#xff1a;如果是文件操作&#xff0c;可以使用FileZilla工具来完成 场景二&#xff1a;安装CentOS桌面 一、CentOS常用命令有哪些&#xff1f; CentOS 系统中有许多常用命令及其用法…...

cmd查看局域网内所有设备ip

说明&#xff1a;最近碰到一个新问题&#xff0c;就是有一个安卓设备&#xff0c;安装了一个app导致死机了&#xff0c;app设置了开机重启&#xff0c;所以&#xff0c;无论重启还是关机&#xff0c;都是进来就白屏&#xff0c; 这可把人愁坏了&#xff0c;直接死循环了 无论…...

5.3作业

这个声明定义了一个名为 s 的数组&#xff0c;数组包含 10 个元素&#xff0c;每个元素都是一个函数指针。(1)C (2)D (3)C (4)DE (5)C8 11 14(1)int IsFull(sequeue *seqn) { return ((seqn->frnt ((seqn->rear 1) % N)) ? 1 : 0); } (2)int IsEmpty(sequ…...

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…...

JavaSec-RCE

简介 RCE(Remote Code Execution)&#xff0c;可以分为:命令注入(Command Injection)、代码注入(Code Injection) 代码注入 1.漏洞场景&#xff1a;Groovy代码注入 Groovy是一种基于JVM的动态语言&#xff0c;语法简洁&#xff0c;支持闭包、动态类型和Java互操作性&#xff0c…...

ssc377d修改flash分区大小

1、flash的分区默认分配16M、 / # df -h Filesystem Size Used Available Use% Mounted on /dev/root 1.9M 1.9M 0 100% / /dev/mtdblock4 3.0M...

高频面试之3Zookeeper

高频面试之3Zookeeper 文章目录 高频面试之3Zookeeper3.1 常用命令3.2 选举机制3.3 Zookeeper符合法则中哪两个&#xff1f;3.4 Zookeeper脑裂3.5 Zookeeper用来干嘛了 3.1 常用命令 ls、get、create、delete、deleteall3.2 选举机制 半数机制&#xff08;过半机制&#xff0…...

LabVIEW双光子成像系统技术

双光子成像技术的核心特性 双光子成像通过双低能量光子协同激发机制&#xff0c;展现出显著的技术优势&#xff1a; 深层组织穿透能力&#xff1a;适用于活体组织深度成像 高分辨率观测性能&#xff1a;满足微观结构的精细研究需求 低光毒性特点&#xff1a;减少对样本的损伤…...

Vite中定义@软链接

在webpack中可以直接通过符号表示src路径&#xff0c;但是vite中默认不可以。 如何实现&#xff1a; vite中提供了resolve.alias&#xff1a;通过别名在指向一个具体的路径 在vite.config.js中 import { join } from pathexport default defineConfig({plugins: [vue()],//…...

Leetcode33( 搜索旋转排序数组)

题目表述 整数数组 nums 按升序排列&#xff0c;数组中的值 互不相同 。 在传递给函数之前&#xff0c;nums 在预先未知的某个下标 k&#xff08;0 < k < nums.length&#xff09;上进行了 旋转&#xff0c;使数组变为 [nums[k], nums[k1], …, nums[n-1], nums[0], nu…...

Sklearn 机器学习 缺失值处理 获取填充失值的统计值

💖亲爱的技术爱好者们,热烈欢迎来到 Kant2048 的博客!我是 Thomas Kant,很开心能在CSDN上与你们相遇~💖 本博客的精华专栏: 【自动化测试】 【测试经验】 【人工智能】 【Python】 使用 Scikit-learn 处理缺失值并提取填充统计信息的完整指南 在机器学习项目中,数据清…...

电脑桌面太单调,用Python写一个桌面小宠物应用。

下面是一个使用Python创建的简单桌面小宠物应用。这个小宠物会在桌面上游荡&#xff0c;可以响应鼠标点击&#xff0c;并且有简单的动画效果。 import tkinter as tk import random import time from PIL import Image, ImageTk import os import sysclass DesktopPet:def __i…...

如何把工业通信协议转换成http websocket

1.现状 工业通信协议多数工作在边缘设备上&#xff0c;比如&#xff1a;PLC、IOT盒子等。上层业务系统需要根据不同的工业协议做对应开发&#xff0c;当设备上用的是modbus从站时&#xff0c;采集设备数据需要开发modbus主站&#xff1b;当设备上用的是西门子PN协议时&#xf…...