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

《探索C语言中数组的奥秘(下)》 - 教程


《探索C语言中数组的奥秘(下)》


前言

学习了二维数组,我们已经基本了解了C语言中数组的使用方式,接下来就让我们进入二维数组的学习吧!
博主C语言专栏:C语言
在这里插入图片描述

一、二维数组的创建

1.1⼆维数组的概念

⼀维数组的数组的元素都是内置类型的,如果我们把***⼀维数组做为数组的元素这时候就是⼆维数组***,⼆维数组作为数组元素的数组被称为三维数组,⼆维数组以上的数组统称为多维数组。
在这里插入图片描述

1.2二维数组的创建

语法规则:
type arr_name[常量值1][常量值2];
例如:
int arr[3][5];
double data[2][8];

解释:上述代码中出现的信息
• 3表⽰数组有3行
• 5表⽰每一行有5个元素
• int表⽰数组的每个元素是整型类型
• arr是数组名,可以根据自己的需要指定名字
data数组意思基本⼀致。

二、二维数组的初始化

在一维数组的初始化基础上做了一些改变:

2.1不完全初始化

int arr1[3][5] = {1,2};
int arr2[3][5] = {0};

在这里插入图片描述

2.2完全初始化

int arr3[3][5] = {1,2,3,4,5, 2,3,4,5,6, 3,4,5,6,7};

在这里插入图片描述

2.3按照行初始化

int arr4[3][5] = {{1,2},{3,4},{5,6}};

在这里插入图片描述

2.4 初始化时省略行,但是不能省略列

int arr5[][5] = {1,2,3};
int arr6[][5] = {1,2,3,4,5,6,7};
int arr7[][5] = {{1,2}, {3,4}, {5,6}};

在这里插入图片描述

三、维数组的使用

3.1 二维数组的下标

⼆维数组访问也是***使⽤下标的形式***的,⼆维数组是有行和列的,***只要锁定了行和列就能唯⼀锁定***数组中的⼀个元素
注:C语⾔规定,⼆维数组的行是从0开始的,列也是从0开始的
例:

int arr[3][5] = {1,2,3,4,5, 2,3,4,5,6, 3,4,5,6,7};

在这里插入图片描述
比如,我们说:第2行,第4列,快速就能定位出7
代码演示:

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

运行结果:
在这里插入图片描述

3.2二维数组的输入和输出

只要能够按照⼀定的规律产⽣所有的行和列的数字就行;以上⼀段代码中的arr数组为例,行的选择范围是***0~~2,列的取值范围是0~4***,所以我们可以***借助循环***实现生成所有的下标
例:

#include <stdio.h>int main(){int arr[3][5] = { 1,2,3,4,5, 2,3,4,5,6, 3,4,5,6,7 };int i = 0;//遍历⾏ //输⼊ for (i = 0; i < 3; i++) //产⽣⾏号 {int j = 0;for (j = 0; j < 5; j++) //产⽣列号 {scanf("%d", &arr[i][j]); //输⼊数据 }}printf("\n");//输出 for (i = 0; i < 3; i++) //产⽣⾏号 {int j = 0;for (j = 0; j < 5; j++) //产⽣列号 {printf("%d ", arr[i][j]); //输出数据 }printf("\n");   //打印一行后换行}return 0;}

运行结果:
在这里插入图片描述

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

了解二维数组的内存存储方式对后期学习指针有重大意义希望大家认真学习
在这里插入图片描述
例:

#include <stdio.h>int main(){int arr[3][5] = { 0 };int i = 0;int j = 0;for (i = 0; i < 3; i++){for (j = 0; j < 5; j++){printf("&arr[%d][%d] = %p\n", i, j, &arr[i][j]);}}return 0;}

运行结果:
在这里插入图片描述
从结果来看,每⼀行内部的每个元素都是相邻的,地址之间相差4个字节,跨行位置处的两个元素(如:arr[0][4]和arr[1][0])之间也是差4个字节,所以***⼆维数组中的每个元素都是连续存放***的。

如图所示:
在这里插入图片描述

四、C99中的变长数组

在C99标准之前,C语⾔在创建数组的时候,数组大小的指定只能使⽤常量、常量表达式,或者如果我们初始化数据的话,可以省略数组大小。
例:

int arr1[10];
int arr2[3+5];
int arr3[] = {1,2,3};

劣势:这样的语法限制,让我们创建数组就不够灵活,有时候数组⼤了浪费空间,有时候数组又小了不够用。
改进:C99中给⼀个变长数组(variable-lengtharray,简称VLA)的新特性,允许我们可以使用变量指定数组大小。
例:

int n = a+b;
int arr[n];

注:数组 arr 就是变⻓数组,因为它的⻓度取决于变量 n 的值,编译器没法事先确定,只有运⾏时才能知道 n 是多少
注:变⻓数组的根本特征,就是数组长度只有运行时才能确定,所以变长数组不能初始化
例:

#include <stdio.h>int main(){int n = 0;scanf("%d", &n);//根据输⼊数值确定数组的⼤⼩ int arr[n];int i = 0;for (i = 0; i < n; i++){scanf("%d", &arr[i]);}for (i = 0; i < n; i++){printf("%d ", arr[i]);}return 0;}

运行结果:
在这里插入图片描述

五、数组的练习

接下来让我们继续一鼓作气,完成几道练习吧!

在这里插入图片描述

练习1:多个字符从两端移动,向中间汇聚

大家可以自己敲一遍,不会在来看看笔者的代码

#include <stdio.h>int main(){char arr1[] = "welcome to bit...";char arr2[] = "#################";int left = 0;int right = strlen(arr1) - 1;printf("%s\n", arr2);while (left <= right){Sleep(1000);  //暂停程序执行时间arr2[left] = arr1[left];arr2[right] = arr1[right];left++;right--;printf("%s\n", arr2);}return 0;}

运行结果:
在这里插入图片描述

练习2:二分查找

什么是二分查找:
⽐如我买了⼀双鞋,你好奇问我多少钱,我说不超过300元。你还是好奇,你想知道到底多少,我就让你猜,你会怎么猜?你会1,2,3,4…这样猜吗?显然很慢;⼀般你都会猜中间数字,⽐如:150,然后看⼤了还是⼩了,这就是***⼆分查找,也叫折半查找。***
解:

#include <stdio.h>int main(){int arr[] = { 1,2,3,4,5,6,7,8,9,10 };int left = 0;int right = sizeof(arr) / sizeof(arr[0]) - 1;int key = 7;//要找的数字 int mid = 0;//记录中间元素的下标 int find = 0;while (left <= right){mid = (left + right) / 2;if (arr[mid] > key){right = mid - 1;}else if (arr[mid] < key){left = mid + 1;}else if (arr[mid] == key){find = 1;break;}}if (find == 1)printf("找到了,下标是%d\n", mid);elseprintf("未找到");return 0;}

运行结果:
在这里插入图片描述

六、总结

数组章节的内容就是这些,希望喜欢笔者文章的朋友点点赞点点关注我们下期见,bye。

在这里插入图片描述

http://www.hskmm.com/?act=detail&tid=34363

相关文章:

  • Java异步编程难题拆解
  • 2025年智能防爆灯/工矿灯厂家推荐排行榜,专业安全与高效照明解决方案!
  • 预测不可预测之物的校准学习技术
  • 2025年水产养殖设备厂家推荐排行榜,PP鱼池/微滤机/不锈钢微滤机/锦鲤池微滤机一体机/全自动污水过滤器/生物过滤器/循环水养殖系统公司推荐!
  • Java 无锁方式实现高性能线程
  • java语言程序设计类与对象课后作业 - 20243867孙堃2405
  • 详细介绍:2020年美国新冠肺炎疫情数据分析与可视化
  • java流程控制。
  • Java基础——包机制,JavaDoc生成文档
  • Misaka2298 的写题自检表
  • Java 中 NullPointerException 的 3 个常见原因及解决
  • Java 方法参数传递:到底是值传递还是引用传递?
  • ES6 箭头函数
  • mysql嵌套查询如何利用索引?
  • 解码Linux文件IO之LCD屏原理及应用
  • centos 7.9快速部署ARL(Asset Reconnaissance Lighthouse)资产侦察灯塔系统用于信息收集
  • 3 分钟搞懂 Java 中 this 关键字的用法
  • 折腾笔记[32]-windows部署vscode-server及使用命令行编译c#.net工程
  • Java 中 ArrayList 和 LinkedList 的选择技巧
  • Java 静态方法为什么不能访问非静态成员?
  • 2025润滑油厂家推荐:三特石化全合成长效发动机油,品质卓越!
  • Java 类与对象实践:从代码验证到四则运算开发
  • CF1032F Vasya and Maximum Matching
  • ctf常见编码
  • WPS中Mathtype插件消失不见解决方法
  • 2025气泡膜机优质厂家推荐:瑞康机械,高效生产与定制服务兼备!
  • 音视频编解码全流程之用Extractor后Decodec - 实践
  • P8817 [CSP-S 2022] 假期计划 解题笔记
  • 2025年塑料托盘厂家推荐排行榜,网格川字/九脚/田字/双面塑料托盘,平板/吹塑/注塑/焊接/印刷/组装款/高矮脚/反川字/立体库托盘公司精选!
  • 物理感知 RTL 合成