【C语言】 数组:-- 一维数组 -- 二维数组 -- 数组越界 -- 数组作为函数的参数3

简介: 【C语言】 数组:-- 一维数组 -- 二维数组 -- 数组越界 -- 数组作为函数的参数3

3、二维数组

3.1 二维数组的创建

//二维数组
int arr[3][4];//三行四列
char arr[3][5];//三行五列
double arr[2][4];//两行四列

3.2 二维数组的初始化

二维数组也是的行列也是从 0 开始的,它是一行放满了再放下一行。

int arr[3][4] = { 1,2,3,4,5,6,7,8,9,10,11,12 };

比如这个代码:

#include <stdio.h>
int main()
{ 
  int arr[3][4] = { 1,2,3,4,5,6,7,8,9,10,11,12 };
  int i = 0;
  for (i = 0; i < 3; i++)
  {
    int j = 0;
    for (j = 0; j < 4; j++)
    {
      printf("%3d", arr[i][j]);
    }
    printf("\n");
  }
  return 0;
}

效果展示:

注:二维数组的列不能省略,行可以省略

二维数组也可以不完全初始化,我们来看看效果:


没有初始化的部分也是用 0 来代替。

二维数组想要找哪个元素也是用下标来找

比如:在一下代码找第二行第一列的数字

#include <stdio.h>
int main()
{ 
  int arr[3][4] = { 1,2,3,4,5,6,7,8,9,10,11,12 };
  printf("%d", arr[1][0]);
  return 0;
}

效果展示:

要找哪一行那一列的数字就给相对应的横纵坐标各 -1 处理。


如果我们想要给每一行放入我们想要放入的数字可以使用下面的方法:


比如,第一行放入1 2 3,第二行放入4 5 6,第三行放入7 8 9。


int arr[3][4] = { {1,2,3},{4,5,6},{7,8,9} };//每一行的数在使用一个{}括起来

效果展示:


这样就可以得到我们想要的结果了。

3.3 二维数组的使用

二维数组的使用也是通过下标的方式。

看代码:

#include <stdio.h>
int main()
{ 
  int arr[3][4] = { 0 };
  int i = 0;
  for (i = 0; i < 3; i++)//行:0 1 2
  {
    int j = 0;
    for (j = 0; j < 4; j++)//列:0 1 2 3
    {
      arr[i][j] = i * 4 + j;
    }
  }
  //打印
  for (i = 0; i < 3; i++)//0 1 2
  {
    int j = 0;
    for (j = 0; j < 4; j++)//0 1 2 3
    {
      printf("%2d ", arr[i][j]);
    }
    printf("\n");
  }
  return 0;
}

效果展示:


3.4 二维数组在内存中的存储

我们还是模仿一维数组,把二维数组的地址打印出来看看

看代码:

#include <stdio.h>
int main()
{ 
  int arr[3][3] = { 0 };
  int i = 0;
  for (i = 0; i < 3; i++)//行:0 1 2
  {
    int j = 0;
    for (j = 0; j < 4; j++)//列:0 1 2 3
    {
      printf("%p\n", &arr[i][j]);
      printf("\n");
    }
  }
  return 0;
}

效果展示:


地址仍然是十六进制表示的,并且我们不难发现二维数组是和一维数组一样是连续的,也还是相差 4 ,因为是整形。

如图:

如果我们访问每一行的各个元素:

arr[1][j];//第一行
arr[2][j];//第二行
arr[3][j];//第三行

我们可以将它拆解为三行,每一行就可以看作一个一维数组,那么每一行的一维数组也有数组名。arr[0]就是第一行的数组名;arr[1]就是第二行的数组名;arr[2]就是第三行的数组名。多行就以此类推。

4、数组越界

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

数组的下标规定从 0 开始的,如果数组有 n 个元素,最后一个元素的下标就是 n-1.
所以数组的下标如果小于 0 ,或者大于 n-1,就是数组越界访问了,超出了数组合法空间的访问。

C语言本身是不做数组下标的越界检查,编译器也不一定报错,但是编译器不报错,并不意味着程序就是正确的,所以程序员在写程序时,最好自己做越界的检查。

二维数组的行、列也有可能存在越界。

相关文章
|
2天前
|
算法 C语言
【C语言程序设计——函数】利用函数求解最大公约数和最小公倍数(头歌实践教学平台习题)【合集】
本文档介绍了如何编写两个子函数,分别求任意两个整数的最大公约数和最小公倍数。内容涵盖循环控制与跳转语句的使用、最大公约数的求法(包括辗转相除法和更相减损术),以及基于最大公约数求最小公倍数的方法。通过示例代码和测试说明,帮助读者理解和实现相关算法。最终提供了完整的通关代码及测试结果,确保编程任务的成功完成。
25 15
|
2天前
|
C语言
【C语言程序设计——函数】亲密数判定(头歌实践教学平台习题)【合集】
本文介绍了通过编程实现打印3000以内的全部亲密数的任务。主要内容包括: 1. **任务描述**:实现函数打印3000以内的全部亲密数。 2. **相关知识**: - 循环控制和跳转语句(for、while循环,break、continue语句)的使用。 - 亲密数的概念及历史背景。 - 判断亲密数的方法:计算数A的因子和存于B,再计算B的因子和存于sum,最后比较sum与A是否相等。 3. **编程要求**:根据提示在指定区域内补充代码。 4. **测试说明**:平台对代码进行测试,预期输出如220和284是一组亲密数。 5. **通关代码**:提供了完整的C语言代码实现
38 24
|
2天前
|
存储 算法 C语言
【C语言程序设计——函数】素数判定(头歌实践教学平台习题)【合集】
本内容介绍了编写一个判断素数的子函数的任务,涵盖循环控制与跳转语句、算术运算符(%)、以及素数的概念。任务要求在主函数中输入整数并输出是否为素数的信息。相关知识包括 `for` 和 `while` 循环、`break` 和 `continue` 语句、取余运算符 `%` 的使用及素数定义、分布规律和应用场景。编程要求根据提示补充代码,测试说明提供了输入输出示例,最后给出通关代码和测试结果。 任务核心:编写判断素数的子函数并在主函数中调用,涉及循环结构和条件判断。
39 23
|
1天前
|
存储 编译器 C语言
【C语言程序设计——函数】回文数判定(头歌实践教学平台习题)【合集】
算术运算于 C 语言仿若精密 “齿轮组”,驱动着数值处理流程。编写函数求区间[100,500]中所有的回文数,要求每行打印10个数。根据提示在右侧编辑器Begin--End之间的区域内补充必要的代码。如果操作数是浮点数,在 C 语言中是不允许直接进行。的结果是 -1,因为 -7 除以 3 商为 -2,余数为 -1;注意:每一个数据输出格式为 printf("%4d", i);的结果是 1,因为 7 除以 -3 商为 -2,余数为 1。取余运算要求两个操作数必须是整数类型,包括。开始你的任务吧,祝你成功!
15 1
|
1月前
|
存储 程序员 C语言
【C语言】文件操作函数详解
C语言提供了一组标准库函数来处理文件操作,这些函数定义在 `<stdio.h>` 头文件中。文件操作包括文件的打开、读写、关闭以及文件属性的查询等。以下是常用文件操作函数的详细讲解,包括函数原型、参数说明、返回值说明、示例代码和表格汇总。
59 9
|
算法 编译器 程序员
C语言学习笔记—P11(数组<2>+图解+题例+三子棋游戏<初级>)
C语言学习笔记(数组<2>+图解+题例+三子棋游戏<初级>)
140 0
C语言学习笔记—P11(数组<2>+图解+题例+三子棋游戏<初级>)
|
存储 C语言
C语言学习笔记—P10(数组<1>+图解+题例)
C语言学习笔记(数组<1>+图解+题例)
153 0
|
C语言
C语言学习笔记——数组(二)
C语言学习笔记——数组
189 0
C语言学习笔记——数组(二)
|
C语言
C语言学习笔记——数组(一)
C语言学习笔记——数组
175 0
C语言学习笔记——数组(一)
|
机器学习/深度学习 C语言 编译器
【C语言】学习笔记4——数组
我直接把控制语句和循环跳过了。大致看了一下,讲得太繁琐了。这部分在后面用C写数据结构就可以练得很熟了。 1. 数组: 由数据类型相同得一系列元素组成。内存上是一片连续得存储单元。 2. 声明 int nums[5] // 内含5个int类型元素的数组 float ...
1008 0