【C 语言】数组 ( 多维数组操作模型 | 取某个数组元素地址 | 取某个数组元素值 )

简介: 【C 语言】数组 ( 多维数组操作模型 | 取某个数组元素地址 | 取某个数组元素值 )

文章目录

一、多维数组操作模型

1、取出某个数组元素地址

2、取出某个数组元素值

总结





一、多维数组操作模型



// 声明一个多维数组
    int array[2][3];


二维数组为例 ;



1、取出某个数组元素地址


第 0 00 行 , 第 1 11 列 元素地址 :


array[0] + 1 : array 代表 二维数组首元素地址 , array[0] 是数组首元素值 , 该值是 一维数组 , 数组名是数组首元素地址 , 数组名 + 1 就是第 1 11 个元素的地址 ;

*array + 1 : array 是 二维数组首元素地址 , *array 是二维数组第 0 00 个元素的值 , 该值是 一维数组 , *array 一维数组名是数组首元素地址 , *array + 1 步长是一维数组元素大小 , 指向第 1 11 个元素地址 ;

&a[0][1] : a[0][1] 是 第 0 00 行 , 第 1 11 列 元素变量 , 取地址 , 就是取该变量的地址 , 也就是 第 0 00 行 , 第 1 11 列元素的地址 ;


第 i ii 行 , 第 j jj 列 元素地址 :


array[i] + j : array 代表 二维数组首元素地址 , array[i] 是二维数组第 i ii 元素值 , 该值是 一维数组 , 数组名是数组首元素地址 , 数组名 + j 就是第 j jj 个元素的地址 ;

*(array + i) + j : array + i 是 二维数组 第 i ii 个元素地址 , *(array + i) 是二维数组第 i ii 个元素的值 , 该值是 一维数组 , *(array + i) 一维数组名是数组首元素地址 , *array + j 步长是一维数组元素大小 , 指向第 j jj 个元素地址 ;

&a[i][j] : a[i][j] 是 第 i ii 行 , 第 j jj 列 元素变量 , 取地址 , 就是取该变量的地址 , 也就是 第 i ii 行 , 第 j jj 列元素的地址 ;


2、取出某个数组元素值


取出某个元素值 , 就是在上面的 " 第 i ii 行 , 第 j jj 列 元素地址 " 基础上 , 加上 * 取该地址对应的值 ;


第 i ii 行 , 第 j jj 列 元素值 :


*(array[i] + j)

*(*(array + i) + j) ;

a[i][j] ;




总结

上述不同操作的由来 , 就是因为 , 数组 既可以使用 [] 下标的方式访问 , 又可以使用 指针 * 符号访问 ;


二维数组中 , 还可以使用 [] 符号访问一维数组 , 之后再使用 * 指针访问一维数组中的元素 ;


目录
相关文章
|
26天前
|
存储 人工智能 程序员
一文彻底搞明白C语言的数组
本文详细介绍了C语言中的数组,包括定义、初始化(静态与动态)、存储方式、访问方法及常用操作,如遍历、修改元素和作为函数参数传递。数组是C语言中最基本的数据结构之一,掌握它对编程至关重要。下篇将介绍二维数组,敬请期待!
37 0
一文彻底搞明白C语言的数组
|
3月前
|
传感器 算法 安全
【C语言】两个数组比较详解
比较两个数组在C语言中有多种实现方法,选择合适的方法取决于具体的应用场景和性能要求。从逐元素比较到使用`memcmp`函数,再到指针优化,每种方法都有其优点和适用范围。在嵌入式系统中,考虑性能和资源限制尤为重要。通过合理选择和优化,可以有效提高程序的运行效率和可靠性。
274 6
|
4月前
|
存储 缓存 算法
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式,强调了合理选择数据结构的重要性,并通过案例分析展示了其在实际项目中的应用,旨在帮助读者提升编程能力。
116 5
|
4月前
|
存储 程序员 编译器
C 语言数组与指针的深度剖析与应用
在C语言中,数组与指针是核心概念,二者既独立又紧密相连。数组是在连续内存中存储相同类型数据的结构,而指针则存储内存地址,二者结合可在数据处理、函数传参等方面发挥巨大作用。掌握它们的特性和关系,对于优化程序性能、灵活处理数据结构至关重要。
|
4月前
|
存储 C语言 计算机视觉
在C语言中指针数组和数组指针在动态内存分配中的应用
在C语言中,指针数组和数组指针均可用于动态内存分配。指针数组是数组的每个元素都是指针,可用于指向多个动态分配的内存块;数组指针则指向一个数组,可动态分配和管理大型数据结构。两者结合使用,灵活高效地管理内存。
|
C语言
《C语言程序设计进阶教程》一2.3.6 获取地址
本文讲的是C语言程序设计进阶教程一2.3.6 获取地址,本节书摘来华章计算机《C语言程序设计进阶教程》一书中的第2章,第2.3.6节, Intermediate C Programming[美] 陆永祥(Yung-Hsiang Lu) 著 徐东 译 译更多章节内容可以访问云栖社区“华章计算机”公众号查看。
1071 0
|
2月前
|
存储 算法 C语言
【C语言程序设计——函数】素数判定(头歌实践教学平台习题)【合集】
本内容介绍了编写一个判断素数的子函数的任务,涵盖循环控制与跳转语句、算术运算符(%)、以及素数的概念。任务要求在主函数中输入整数并输出是否为素数的信息。相关知识包括 `for` 和 `while` 循环、`break` 和 `continue` 语句、取余运算符 `%` 的使用及素数定义、分布规律和应用场景。编程要求根据提示补充代码,测试说明提供了输入输出示例,最后给出通关代码和测试结果。 任务核心:编写判断素数的子函数并在主函数中调用,涉及循环结构和条件判断。
97 23
|
26天前
|
人工智能 Java 程序员
一文彻底搞清楚C语言的函数
本文介绍C语言函数:函数是程序模块化的工具,由函数头和函数体组成,涵盖定义、调用、参数传递及声明等内容。值传递确保实参不受影响,函数声明增强代码可读性。君志所向,一往无前!
21 1
一文彻底搞清楚C语言的函数
|
2月前
|
算法 C语言
【C语言程序设计——函数】利用函数求解最大公约数和最小公倍数(头歌实践教学平台习题)【合集】
本文档介绍了如何编写两个子函数,分别求任意两个整数的最大公约数和最小公倍数。内容涵盖循环控制与跳转语句的使用、最大公约数的求法(包括辗转相除法和更相减损术),以及基于最大公约数求最小公倍数的方法。通过示例代码和测试说明,帮助读者理解和实现相关算法。最终提供了完整的通关代码及测试结果,确保编程任务的成功完成。
122 15
|
2月前
|
C语言
【C语言程序设计——函数】亲密数判定(头歌实践教学平台习题)【合集】
本文介绍了通过编程实现打印3000以内的全部亲密数的任务。主要内容包括: 1. **任务描述**:实现函数打印3000以内的全部亲密数。 2. **相关知识**: - 循环控制和跳转语句(for、while循环,break、continue语句)的使用。 - 亲密数的概念及历史背景。 - 判断亲密数的方法:计算数A的因子和存于B,再计算B的因子和存于sum,最后比较sum与A是否相等。 3. **编程要求**:根据提示在指定区域内补充代码。 4. **测试说明**:平台对代码进行测试,预期输出如220和284是一组亲密数。 5. **通关代码**:提供了完整的C语言代码实现
70 24