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

海珠区建设和水务局网站网站建设夜猫

海珠区建设和水务局网站,网站建设夜猫,如何做婚恋网站,注册域名需要多久目录 一维数组 二维数组 数组越界 数组作为函数参数 一维数组 数组是一组相同类型元素的集合。 创建数组 type arr[n] {...} type是数组的元素类型; arr 是数组名; n 是常量或常量表达式,用来指定数组的大小。 根据数组的索引来获取对…

目录

一维数组

二维数组

数组越界

数组作为函数参数


一维数组

数组是一组相同类型元素的集合。

创建数组

type arr[n] = {...}  

type是数组的元素类型; arr 是数组名; n 是常量或常量表达式,用来指定数组的大小。

根据数组的索引来获取对应元素,索引从 0 开始。

不写 n  的值,则根据大括号中的元素个数自动分配空间。

在C99标准之前,数组的大小必须是常量或常量表达式。

在C99标准之后,数组的大小可以是变量,为了支持变长数组,变长数组不能初始化。

数组的初始化

数组的初始化是指,在创建数组的同时给数组的内容一些合理的初始值(初始化)。

如 intarr[10] = {1,2,3}        // 不完全初始化,剩下的元素默认初始化为0

一维数组的使用

[] , 下标引用操作符。它其实就是数组访问的操作符。

计算数组元素个数

sizeof ( arr ) / sizeof ( arr[0] ) 

一维数组在内存中的存储

数组在内存中是连续存放的。随着数组下标的增加,地址也按数组元素大小的跨度(step)增加。

二维数组

二维数组创建

type arr[a][b]        // 创建一个 a 行 b 列的数组

例:int arr[2][3] = {1,2,3,4,5,6};   // 按元素个数自动分配

例:int arr[2][3] = { {1, 2} , { 3, 4, 5} };         // 自己定义每行的元素

例:int arr[ ][3] = {1,2,3,4,5,6};         // 可以省略行数,但不能省略列数

二维数组的使用

行和列的索引都是从 0 开始的。

可以通过嵌套循环的方式遍历数组。

计算二维数组的元素个数

sizeof (arr)  /  sizeof (arr[0][0]) 

二维数组在内存中的存储

同一维数组一样,二维数组在内存中也是连续存放的。二维数组的存放按 行 展开(reshape(1, -1))。随着数组下标的增加,地址也按数组元素大小的跨度(step)增加。

数组越界

数组的下标是有范围限制的。

数组的下标规定是从0开始的,如果数组有n个元素,最后一个元素的下标就是 n-1。

所以数组的下标如果小于0, 或者大于 n-1, 就是数组越界访问了,超出了数组合法空间的访问。

C语言本身是不做数组下标的越界检查,编译器也不一定报错(越界的部分会打印随机值),但是编译器不报错,并不意味着程序就是正确的。

数组作为函数参数

注意:当数组作为参数传递给函数时,不能在函数内部计算数组的大小。

因为传进函数的数组名(arr)是数组首元素地址(&arr[0])

// 数组传参, 形参有两种写法
// 数组的形式,指针的形式
// 形参是数组的形式
void bubble_sort(int arr[], int sz) {// 趟数// 传进来的arr是首元素的地址,无法使用sizeof计算数组的长度,应该直接传递一个sz的参数//int sz = sizeof(arr) / sizeof(arr[0]);int i = 0;for (i = 0; i <= sz - 1; i++) {// 一趟冒泡排序int j = 0;// 每增加一趟,每趟冒泡排序的次数就少一次for (j = 0; j < sz-1-i; j++) {if (arr[j] > arr[j + 1]) {// 交换int temp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = temp; }}}}// 冒泡排序,升序
int main() {int arr[] = {9,8,7,6,5,4,3,2,1,0};int sz = sizeof(arr) / sizeof(arr[0]);bubble_sort(arr, sz);  // 数组传参只传数组名for (int i = 0; i < sz; i++) {printf("%d ", arr[i]);}return 0;
}

数组名确实能表示首元素的地址

但是有两个例外:

1.sizeof(数组名), 这里的数组名表示整个数组,计算的是整个数组的大小,单位是字节

2.&数组名,这里的数组名表示整个数组,取出的是整个数组的地址。 

int main() {int arr[] = { 1,2,3,4,5 };printf("%p\n", arr);printf("%p\n", arr+1); // 加的是一个元素的长度printf("----------------------\n");printf("%p\n", &arr[0]);printf("%p\n", &arr[0]+1);	// 加的是一个元素的长度printf("----------------------\n");printf("%p\n", &arr);printf("%p\n", &arr+1);	// 加的是一个数组的长度return 0;
}

二维数组的数组名(arr)也表示首元素地址, 表示的是 arr[0] 这一行的地址。

int main() {int arr[3][4];int sz = sizeof(arr);printf("%zu\n", sz);// 打印行数int sz_row = sizeof(arr) / sizeof(arr[0]);printf("%zu\n", sz_row);// 打印列数int sz_col = sizeof(arr[0]) / sizeof(arr[0][0]);printf("%zu\n", sz_col);printf("%p\n", arr);printf("%p\n", arr+1);return 0;
}

http://www.dtcms.com/a/473705.html

相关文章:

  • 用 Go 优雅应对网络抖动与断线重连:打造健壮的网络应用
  • C++ : 智能指针的补充和特殊类的设计
  • 【完整源码+数据集+部署教程】 航拍水体检测图像分割系统源码和数据集:改进yolo11-DLKA
  • 公司查询网站查询系统景点介绍网站开发设计
  • 如何定位 TCP TIME_WAIT ,并优化这个问题
  • DDD记账软件实战四|从0-1设计实现企业级记账微服务
  • 考研408《计算机组成原理》复习笔记,第七章(1)——I/O接口
  • 建设部网站在哪里报名考试大德通网站建设
  • Java 泛型基础:从类型安全到泛型类 / 方法 / 接口全解析
  • git 绑定多个远程仓库指定推送场景
  • 前端学习2:学习时间3-4小时
  • setup与选项式API
  • 后端开发是什么:从服务器到数据库
  • 南宁3及分销网站制作大连建设网信息公开
  • 神经网络中的非线性激活函数:从原理到实践
  • 【IO多路复用】原理与选型(select/poll/epoll 解析)
  • AI 与神经网络:从理论到现代应用
  • 消息积压的问题如何解决
  • 神经网络常用激活函数公式
  • 回归预测 | MATLAB实现CNN(卷积神经网络)多输入单输出+SHAP可解释分析+新数据预测
  • 中国十大旅游网站wordpress视频试看付费
  • Docker部署的gitlab升级的详细步骤(升级到17.6.1版本)
  • 一个基于稀疏混合专家模型(Sparse Mixture of Experts, Sparse MoE) 的 Transformer 语言模型
  • Litho项目架构解析:四阶段流水线如何实现自动化文档生成
  • 济南建站免费模板logo制作用什么软件
  • Docker为什么比虚拟机资源利用率高,启动快
  • AI 颠覆室内设计:SpatialGen 实现 “一句话生成 3D 房间”
  • 有序逻辑回归的概念、适用场景、数据要求,以及其在Stata中的操作命令及注意事项,Stata ologit回归结果怎么看?并附详细示例
  • PHP开发环境搭建
  • 门户网站与官网的区别做照片的ppt模板下载网站