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

news2024/9/23 15:28:25

本章的学习内容如下 

四、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.coloradmin.cn/o/1534554.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

10.注册页面

注册页面 在pages中新建页面register 复制粘贴之前的登录页面 设置上传头像图片 微信官方文档 https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/userProfile.html <button class"avatar-wrapper" open-type"chooseAvatar&quo…

微调alpaca-lora遇到的一些问题

1、环境简介 环境&#xff1a; 系统&#xff1a;Ubuntu torch&#xff1a;2.2.1 python&#xff1a;3.10 gpu&#xff1a;V100 16g peft&#xff1a;0.9.0 使用PEFT中的lora方式微调llama-2-7b-hf&#xff0c;项目地址&#xff1a;alpaca-lora 2、混合精度训练Tensor相互计算会…

海外重要行业媒体:知名服务商IntoTheBlock现已集成波场TRON网络分析数据

近日,领先链上分析服务提供商 IntoTheBlock 宣布已将波场 TRON 网络集成至其市场情报套件。该合作引发多家海外加密媒体关注,Crypto Slate、Crypto Briefing等均对此进行了报道,称此次合作意义深远,能帮助数百万用户更深入地了解波场TRON生态系统。 报道表示,波场TRON网络规模大…

中文编程入门(Lua5.4.6中文版)第十一章 Lua 模块与包 参考星争际霸游戏

在遥远的星争际霸世界中&#xff0c;代码模块就如同星际基地中的高科技仓库&#xff0c;储存着各类经过封装优化的战术指令和战略资源。自Lua 5.1版本起&#xff0c;星际编程者们引入了标准化的模块管理系统&#xff0c;使得不同战舰之间能够共享和调用核心战斗算法&#xff0c…

Linux-网络层IP协议、链路层以太网协议解析

目录 网络层&#xff1a;IP协议地址管理路由选择 链路层 网络层&#xff1a; 网络层&#xff1a;负责地址管理与路由选择 — IP协议&#xff0c;地址管理&#xff0c;路由选择 IP协议 数据格式&#xff1a; 4位协议版本&#xff1a;4-ipv4协议版本 4位首部长度&#xff1a;以…

Redis实战:缓存穿透及其解决思路 实战演示

&#x1f389;&#x1f389;欢迎光临&#xff0c;终于等到你啦&#x1f389;&#x1f389; &#x1f3c5;我是苏泽&#xff0c;一位对技术充满热情的探索者和分享者。&#x1f680;&#x1f680; &#x1f31f;持续更新的专栏Redis实战与进阶 本专栏讲解Redis从原理到实践 …

Python爬虫框架大比拼!从小爬虫到大数据采集|电商大数据采集API接口

在互联网时代&#xff0c;数据是无处不在的黄金。无论你是寻找小规模的数据采集任务还是大规模的网络爬虫项目&#xff0c;Python提供了丰富的爬虫框架供你选择。对于小型爬虫需求&#xff0c;你可能会喜欢使用requests库和Beautiful Soup(bs4库)这样的基本工具&#xff0c;它们…

想当初级爬虫工程师,需要把爬虫学到什么程度?

这篇文章会说说我自己的心得体验&#xff0c;关于爬虫、关于工作&#xff0c;仅供参考。 学到哪种程度 暂且把目标定位初级爬虫工程师&#xff0c;简单列一下吧&#xff1a; &#xff08;必要部分&#xff09; 语言选择&#xff1a;一般是了解Python、Java、Golang之一 熟悉…

C#操作像素替换图片中的指定颜色

待处理的图片&#xff0c;其特征是包含有限数量颜色&#xff0c;不同的颜色相互交叉使用&#xff0c;相同颜色并未完全连贯&#xff0c;需要将图片中的指定颜色替换为另一颜色。虽然很多图片处理工具都支持类似操作&#xff0c;最后还是自己动手编写简单的处理程序。   程序的…

尚硅谷SQL|数据库的创建,修改与删除

DDL&#xff1a;创建和管理表 DDL所有的操作都要慎重&#xff0c;尤其是删除&#xff0c;清空等。 创建数据库--->确认字段--->创建数据表---->插入数据 创建数据库 1.创建数据库&#xff1a;推荐使用方式3 #创建数据库 #方式1,使用的是默认字符集 create databa…

24计算机考研调剂 | (研究所)北京微电子技术研究所

北京微电子技术研究所2024年考研调剂信息 调剂信息 一、招生专业 二、调剂对象 统考科目为思想政治理论、英语&#xff08;一&#xff09;、数学&#xff08;一&#xff09;&#xff1b;本科为电子科学与技术、微电子学、集成电路设计、电子信息工程、通信工程、计算机科学与…

有关Theano和PyTensor库

根据Github里面的介绍&#xff0c;PyTensor是源于Theano&#xff0c; Theano目前应该已经不再开发了&#xff0c;更新都是很多年前。 因此PyTensor在背景介绍中说 PyTensor is a fork of Aesara, which is a fork of Theano. Theano和PyTensor都是计算相关的库&#xff0c;可以…

报数游戏-第12届蓝桥杯选拔赛Python真题精选

[导读]&#xff1a;超平老师的Scratch蓝桥杯真题解读系列在推出之后&#xff0c;受到了广大老师和家长的好评&#xff0c;非常感谢各位的认可和厚爱。作为回馈&#xff0c;超平老师计划推出《Python蓝桥杯真题解析100讲》&#xff0c;这是解读系列的第39讲。 报数游戏&#xf…

VMware 替代专题 | 浅析 VMware 与 SmartX 超融合 I/O 路径差异及其影响

不同的超融合软件&#xff0c;其读写机制有一定的差异性&#xff0c;I/O 路径也不尽相同&#xff0c;这使得他们在 I/O 读写效率以及资源占用上都有不同的表现。有兴趣着手构建超融合基础架构的用户&#xff0c;可能会希望了解更多关于 I/O 路径的细节&#xff0c;从而在实施之…

智能商品计划系统:鞋服品牌的未来价值引擎

在数字化浪潮席卷全球的今天&#xff0c;智能商品计划系统正成为鞋服品牌转型升级的重要引擎。那么&#xff0c;什么是智能商品计划系统&#xff1f;它又能给鞋服品牌带来怎样的价值&#xff1f;本文将深入探讨这一话题&#xff0c;为鞋服品牌企业指引方向。 智能商品计划系统…

京东云开发者:DDD 学习与感悟 —— 向屎山冲锋

原文地址:https://mp.weixin.qq.com/s/Hvq1ttBopbxypatVcKcLiA 软件系统是通过软件开发来解决某一个业务领域或问题单元而产生的一个交付物。而通过软件设计可以帮助我们开发出更加健壮的软件系统。因此&#xff0c;软件设计是从业务领域到软件开发之间的桥梁。而DDD是软件设计…

使用QGIS将shp数据导入到数据库

QGIS将shp数据导入到数据库步骤&#xff1a; 1、在QGIS中查看携带地理坐标的数据&#xff0c;可以右键查看数据的属性数据源&#xff0c;可以修改数据使用的编码&#xff08;防止乱码&#xff09;&#xff0c;如下图 2、选择数据右键Export导出&#xff0c;在导出的页面可以选…

Springboot+vue的高校教师科研管理系统+数据库+报告+免费远程调试

项目介绍: Javaee项目&#xff0c;springboot vue前后端分离项目 本文设计了一个基于Springbootvue的前后端分离的高校教师科研管理系统&#xff0c;采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&#xff09;三层体系结构&#xf…

09 事务和连接池

文章目录 properties文件连接池service层实现类dao层实现类dao层实现类 连接池类: 创建线程池静态常量&#xff0c;用于放连接。 创建Properties静态常量&#xff0c;用于解析properties文件 静态代码块中&#xff0c;解析properties文件&#xff0c;将解析结果用于创建连接池 …

innovus中path group 的策略和应用(下)

BPG&#xff08;basic path group&#xff09;和PG&#xff08;path group&#xff09;的异同 INVS默认使用了BPG&#xff0c;但是基于SDC理论下PG&#xff08;path group&#xff09;也是天然存在&#xff0c;两者在数据库里边有各自存在的方式&#xff0c;也可以共融共生中&…