四、C语言中的数组:如何输入与输出二维数组(数组,完)

本章的学习内容如下 

四、C语言中的数组:数组的创建与初始化
四、C语言中的数组:数组的输入与元素个数
C语言—第6次作业—十道代码题掌握一维数组
四、C语言中的数组:二维数组

 1.二维数组的输入与输出

当我们输入一维数组时需要一个循环来遍历下标,二维数组有两个下标 ,所以我们需要两个循环嵌套使用来遍历下标。

# include <stdio.h>
int main()
{int arr[3][4] = { 1,2,3,4,5,6,7,8,9,1,2,3 };//完全初始化int i = 0;int j = 0;for (i = 0; i < 3; i++) {for (j = 0; j < 4; j++) {scanf("%d", &arr[i][j]);//输入
}}for (i = 0; i < 3; i++) {for (j = 0; j < 4; j++) {printf("% d", arr[i][j]);}printf("\n");//按数组的行换行}return 0;
}

2.二维数组的存储

打印每一个元素的地址,我们可以发现,每个元素是按00,01,02,03,10.....的下标顺序存储的,每个整型元素占四个字节的空间。

# include <stdio.h>
int main()
{int arr[3][4] = { 1,2,3,4,5,6,7,8,9,1,2,3 };//完全初始化int i = 0;int j = 0;for (i = 0; i < 3; i++) {for (j = 0; j < 4; j++) {printf("&arr[%d][%d] = %p\n", i, j, &arr[i][j]);//打印每一个元素的地址}}return 0;
}

3.变长数组

数组的长度用变量指定,无需初始化

int n = a+b;
int arr[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;
}

4.数组练习题:二分法查找数组中的某个元素

效率会比遍历整个数组高一半。二分查找(折半查找) 的规则:在一个升序数组中找到这个元素的下标即能定位到这个元素,不断折半查找与想要找到的这个元素进行对比,即可得到这个元素所在的区间,不断缩小区间,就可以得到这个元素的所在位置。

4.1冒泡排序

所以第一步应该是对现有的数组进行升序排列。我们可以使用冒泡排序的方法,将数组的元素按顺序两两对比,符合升序的位置不变,不符合升序的位置交换。

比如当我们初始化一个数组int arr[9] = {5,78,43,2,3,5,7,9,156};第一个循环是i从0开始依次对比arr[i]和arr[i+1]的大小,当条件if (arr[i] >= arr[i + 1])成立时,交换位置,在交换的过程中,使用中间变量来暂存;经过一轮对比,我们得到156这个最大值的正确位置。最大值156确定后,排除这个数,将剩下的值依次找到最大值,所以这是一个嵌套循环,在代码撰写的过程中,记住检查各个变量的值,注意不要溢出。

如下图所示我们可以看到,现在的数组arr[]已经被升序排列,接下来让我们继续实现二分查找。

# include <stdio.h>
int main() 
{int arr[9] = {5,78,43,2,3,5,7,9,156};int length = sizeof(arr) / sizeof(arr[0]);int i = 0;int j = 0;int r = 0;for (j = length-1;j > 0;j--) {for (i = 0; i < j; i++) {int temp = 0;if (arr[i] >= arr[i + 1]) {int temp = arr[i + 1];arr[i + 1] = arr[i];arr[i] = temp;}}}for (r = 0; r < length; r++) {printf("%d\n", arr[r]);}return 0;
}

 

4.2 二分查找的步骤

  1. 初始化:设定两个指针,分别指向数组的首部和尾部(left = 0right = length of array - 1)。

  2. 循环:当 left <= right 时,执行循环:

    • 找到中间元素的索引 mid = (left + right ) / 2)
    • 比较中间元素与目标值:
      • 如果中间元素等于目标值,说明找到了目标,返回 mid
      • 如果中间元素小于目标值,则说明目标值位于中间元素的右侧,调整 left 指针到 mid + 1
      • 如果中间元素大于目标值,则说明目标值位于中间元素的左侧,调整 right 指针到 mid - 1
  3. 返回结果:如果循环结束仍未找到目标值,说明目标值不存在于数组中,返回 -1 或其他标记值表示未找到。

我们的任务是利用二分查找的方法找到数组中的元素43。如下图所示,我们成功地找出了元素43的数组下标是6。我们把排序和查找的代码联合起来如下所示,这样我们就可以实现一个数组的排序与元素查找啦!

# include <stdio.h>
int main() 
{int arr[9] = {5,78,43,2,3,5,7,9,156};int length = sizeof(arr) / sizeof(arr[0]);int i = 0;int j = 0;int r = 0;for (j = length-1;j > 0;j--) {for (i = 0; i < j; i++) {int temp = 0;if (arr[i] >= arr[i + 1]) {int temp = arr[i + 1];arr[i + 1] = arr[i];arr[i] = temp;}}}/*for (r = 0; r < length; r++) {printf("%d\n", arr[r]);}*/int left = 0;//区间最小值的数组下标int right = length-1;//区间最大值的数组下标int mid = 0;//区间中点值的数组下标int target = 43;//要找的目标元素while (left <= right) {mid = (left + right) / 2; if (target == arr[mid]){printf("%d", mid);break;}else if (target<arr[mid]) {right = mid-1;}else {left = mid + 1;}}return 0;
}

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/557403.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python基础学习笔记(一)

Python简介 Python 语言是一种跨平台、开源、免费、解释型、面向对象、动态数据类型的高级程序设计语言。早期版本的 Python 被称作是 Python1&#xff1b;Python2 最后一个版本是 2.7&#xff1b;Python3 是目前最活跃的版 本&#xff0c;基本上新开发的 Python 代码都会支持…

利用dlib实现人脸识别初体验

前面的文章中介绍了如何编译dlib静态库和动态库&#xff0c;那么下一步就是利用dlib完成一个最简单的识别图片中人脸的程序。该程序参考了一些网上最常用的例子。下面将测试的环境、代码、遇到的问题、解决方法一一列出&#xff0c;供大家参考&#xff0c;希望能给大家一些帮助…

【算法刷题】Day32

文章目录 1. 单词拆分题干&#xff1a;算法原理&#xff1a;1. 状态表示&#xff1a;2. 状态转移方程3. 初始化4. 填表顺序5. 返回值 代码&#xff1a; 2. 环绕字符串中唯一的子字符串题干&#xff1a;算法原理&#xff1a;1. 状态表示&#xff1a;2. 状态转移方程3. 初始化4. …

安卓开发日记:实现APP重启逻辑,适用于热更后重启游戏进行加载

可根据合适的弹窗搭配使用重启逻辑&#xff0c;建议使用在热更包加载后使用&#xff0c;帮助部分热更后未及时生效的逻辑范围首先&#xff0c;在逻辑调用Activity类中创建一个成员变量&#xff0c;给后续逻辑接口直接使用 如下 public class MainActivity extends Activity {…

【Linux】多线程概念 | POSIX线程库

文章目录 一、线程的概念1. 什么是线程Linux下并不存在真正的多线程&#xff0c;而是用进程模拟的&#xff01;Linux没有真正意义上的线程相关的系统调用&#xff01;原生线程库pthread 2. 线程和进程的联系和区别3. 线程的优点4. 线程的缺点5. 线程异常6. 线程用途 二、二级页…

第二十八天-ES6标准入门和Flex布局

目录 1.ES6标准入门 2.ES6与JavaScript关系 3.ES6常用新特性 1.变量与常量 1.let三大特性 2.常量三大特征 2.解构赋值 1.数组解构赋值 2.对象解构赋值 3.字符串解构赋值 3.函数与箭头函数 1.函数 2.箭头函数 4.JS的面向对象编程 5.模块化 export使用 import使用…

Spring——IOC容器介绍

启动ioc容器后 1、Spring容器读取完bean配置信息&#xff08;1、XML中的bean配置信息 2、读取java类中Configuration注解配置的bean信息&#xff09;后&#xff0c;加载到Bean定义的注册表中 2、根据Bean的注册表来创建实例Bean 3、将创建好的Bean实例再放到Spring容器中&…

【Godot4.2】Rect2拓展——mRect2类

概述 Rect2存在一些问题&#xff0c;比如难以获取除position、end和center之外的其他点。虽然计算并不复杂&#xff0c;就是简单的向量加减。但每次手动计算则比较麻烦。 其实在ShapePoints静态函数库中&#xff0c;已经尝试返回矩形的四个顶点&#xff0c;用于绘制矩形。 # …

c++的学习之路:2、入门(1)

一、 C关键字 c的关键字要比c语言要多31个足足有63个&#xff0c;这里我只是了解了下每个有啥作用&#xff0c;具体使用方法以及更多的知识将在后续学习中&#xff0c;慢慢扩展使用&#xff0c;下方表格就是c的63个关键字 asmdoifreturntryautodoubleinlinetypedefdynamic_ca…

归并算法详细解析

归并排序 1945年&#xff0c;约翰冯诺依曼&#xff08;John von Neumann&#xff09;发明了归并排序&#xff0c;这是典型的分治算法的应用。归并排序&#xff08;Merge sort&#xff09;是建立在归并操作上的一种有效的排序算法&#xff0c;该算法是采用分治法&#xff08;Di…

公司系统中了.rmallox勒索病毒如何恢复数据?

早晨上班时刻&#xff1a; 当阳光逐渐洒满大地&#xff0c;城市的喧嚣开始涌动&#xff0c;某公司的员工们纷纷踏入办公大楼&#xff0c;准备开始新的一天的工作。他们像往常一样打开电脑&#xff0c;准备接收邮件、查看日程、浏览项目进展。 病毒悄然发作&#xff1a; 就在员…

Python学习:元组

Python 元组概念 Python 中的元组&#xff08;tuple&#xff09;是不可变的有序集合。它是一种数据类型&#xff0c;类似于列表&#xff08;list&#xff09;&#xff0c;但在创建后不能被修改。元组使用圆括号 () 来表示&#xff0c;其中的元素可以是任意类型&#xff0c;并且…