百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

自学 C++ 第 6 课 二维数组找最值

liuian 2025-01-14 15:20 102 浏览

键盘输入一个m×n的二维数组,通过C++编程找出元素中的最大值,并输出其所在的位置坐标。例如,输入一个4×5的二维数组,数组元素分别为{{55 66 23 74 9},{5 78 96 45 63},{32 74 120 24 12},{26 123 5 38 73}},输出最大值为:123;最大值坐标为:(4,2)。

//程序代码
#include<iostream>  //头文件
#include<vector>  //头文件
using namespace std;  //命名空间
int main()
{
	int m, n, i, j, max, indexx, indexy;
	cout << "请输入二维数组的行数m:" << endl;
	cin >> m;
	cout << "请输入二维数组的列数n:" << endl;
	cin >> n;
	//vector<vector<int> >nums(m, vector<int>(n));  //二维数组
	vector<vector<int> >nums(m);     //二维数组的另一种定义方式
	for (i = 0; i < m; i++)
	{
		nums[i].resize(n);   //resize()函数的应用
	}
	cout << "请输入二维数组的元素:" << endl;
	for (i = 0; i < m; i++)
	{
		for (j = 0; j < n; j++)
		{
			cin >> nums[i][j];   //输入二维数组的元素
			if (i == 0 && j == 0)  //vector数组的坐标从0开始
			{
				max = nums[i][j];  //max的初始值是坐标为0,0的值
				indexx = 0;
				indexy = 0;
			}
			else if (nums[i][j] > max) //判断最大值
			{
				max = nums[i][j];
				indexx = i;
				indexy = j;
			}
		}
	}
	cout << "最大值:" << max << " ;" << "最大值的坐标:" << "(" << indexx + 1 << "," << indexy + 1 << ")" << endl;
	system("pause");
	return 0;
}

知识点:

? 定义二维数组,除了vector<vector<int> >nums(m, vector<int>(n)),还可以灵活地采用resize(n)函数,相当于把原来一维数组的元素都扩充成一个拥有n个元素的一维数组。如果nums是一维数组,nums.size()是指当前数组所存储的元素个数;如果nums是二维数组,nums.size()是指当前数组的行数;nums[0].size()是指当前数组的列数。

? resize() 既修改size()大小,也修改capacity()大小。但要注意,只有在修改后的size()大于当前的capacity()时,resize()才会修改capacity()大小。capacity()是指容器在分配新的存储空间之前能存储的元素总数。如果resize(n)中的n小于当前容器容量(capacity()),则将会移除n个元素后面的其他元素;如果resize(n)中的n大于当前容器容量(capacity()),则自动进行空间分配。

? 跟resize()和capacity()相关的函数还有.clear(),vector.clear()的英文解析是“Removes all elements from the vector (which are destroyed), leaving the container with a size of 0.” 其只用来移除元素,把nums.size置为0,但是不会释放空间,capacity不变。如果需要释放内存空间,可以用swap()。

? 为什么vector要使用capacity的概念?nums.size好比小区的汽车数量,而停车位就是我们需要的空间,如果增加1辆车就要新修1个停车位,这样效率会很低。那么,最好的方法是一开始规划时多建新停车位作为预留,程序中预留空间的想法就是靠capacity实现的。一次性开辟好存储空间,只有空间不足时再去开辟另一个更大的空间,避免每次添加元素都要开辟存储空间。vector元素占用的空间是连续的,如果存储空间不足,需要一个更大的连续空间来移植原来元素和添加新增元素,并释放原来的存储空间。这个过程会耗时导致性能降低。

自学 C++ 第 1 课 数字大小排序

自学 C++ 第 2 课 数组包含关系

自学 C++ 第 3 课 正整数反序输出

自学 C++ 第 4 课 计算体积及表面积

自学 C++ 第 5 课 杨辉三角

相关推荐

万能app破解器(万能app软件破解器)

1、以现有的技术手段,是没有办法破解WPA的加密方式(现在基本上全部WIFI的加密方式),WPA的加密方式安全性很高,根本就破不了。2、即使破解密码,人家也有可能设置了MAC地址过滤,还是上不去。3、...

笔记本电脑自带摄像头怎么开启

要使用笔记本电脑自带的摄像头,请按照以下步骤操作:1.打开你的电脑,进入桌面。2.定位摄像头,通常在笔记本电脑的上部或者展开的屏幕的中央位置。3.双击摄像头图标,或者在键盘上按下对应的快捷键,以...

怎么知道wifi密码(手机连接上wifi怎么知道wifi密码)

关于这个问题,如果您想查看已经连接过的无线网络密码,请按照以下步骤操作:对于Windows10:1.点击任务栏中的WiFi图标,选择“网络和Internet设置”2.在“网络和Internet设...

电脑如何调出任务管理器(电脑如何调出任务管理器快捷键)

在Windows操作系统中,可以通过以下方法调出任务管理器:使用快捷键:按下“Ctrl+Shift+Esc”快捷键组合,即可快速打开任务管理器。使用组合键:按下“Ctrl+Alt+...

win732位怎么还原系统(win732位gho)

系统安装失败,在以前的系统没有备份的情况下,是不能恢复的。只要诺顿开始运行,,不管进度条在什么位置,原系统都被格式化。如果有备份文件,那么方法是:1、打开系统备份还原软件:2、点击浏览,找到备份文件,...

电脑装什么杀毒软件(电脑装什么杀毒软件最安全)

好用的电脑杀毒软件,目前比较知名的有360杀软,腾讯电脑管家,金山毒霸,瑞星等杀毒软件,至于哪一个更好用,就看你自己的习惯了,我个人觉得360比较让人放心一些,这些年也一直用着360,比较安全有保证,...

u盘uefi是什么意思(u盘用uefi模式启动)

u盘启动盘是指在U盘里安装PE版的操作系统后,把系统设置成从U盘启动,然后电脑开机就从U盘开始重装系统。UEFI,全称“统一的可扩展固件接口”,是一种详细描述类型接口的标准。这种接口用于操作系统自动...

qq更新版本下载安装(qq号下载安装2020最新版)
  • qq更新版本下载安装(qq号下载安装2020最新版)
  • qq更新版本下载安装(qq号下载安装2020最新版)
  • qq更新版本下载安装(qq号下载安装2020最新版)
  • qq更新版本下载安装(qq号下载安装2020最新版)
win10系统故障修复工具(win10系统的故障修复界面)
  • win10系统故障修复工具(win10系统的故障修复界面)
  • win10系统故障修复工具(win10系统的故障修复界面)
  • win10系统故障修复工具(win10系统的故障修复界面)
  • win10系统故障修复工具(win10系统的故障修复界面)
天猫积分兑换根本抢不到(2021天猫积分兑换根本抢不到)

因为天猫积分的东西是有限的,但是很多人想要它们。如果你想抢到它,你最好注意启动秒杀的时间,在你启动倒计时时做好准备,并立即点击交换验证码,然后点击确认。一般最慢的时间是十秒内甚至四五秒内下单,五分钟内...

win10任务管理器未响应(win10任务管理器没反应)

未响应这种情况应该是:1、说明程序是正在运行,但由于是系统运行内存不足,或者病毒、垃圾等造成的系统卡顿了。2、可以尝试重启系统、杀毒、清理垃圾即可。解决方法一:双击“此电脑”我的电脑的时候,出现资源管...

新电脑装win7进不了系统(新电脑安装win7系统启动不了)
新电脑装win7进不了系统(新电脑安装win7系统启动不了)

解决方法:1、开机按F8,选择“最好一次正确配置”尝试修复。2、开机按F8,选择“安全模式”尝试修复。3、如果方法1,2不能修复,通过系统还原或者重新安装系统修复。二、如果软件无法修复,仍然无法启动,那么就是硬件故障原因造成的。比如硬盘、主...

2025-12-25 21:55 liuian

台式键盘锁住了打不了字怎么解锁
台式键盘锁住了打不了字怎么解锁

1.找到在键盘上靠左侧的位置,有一个fn的键,按住fn键。2.然后找到键盘最上面f8的键,把fn和f8一起按住,即可完成操作。3.然后此时看到键盘已经解除锁定,就可以可以正常输入了,这样就完成了键盘的解锁操作。...

2025-12-25 21:05 liuian

怎么超频显卡(显卡怎么超频使用)

显卡超频犯法如下:1、首先是显卡体质的检测,如果不知道显卡的体质,盲目加电压或者频率很容易导致超频的失败,检测显卡体质需要用到软件超频和拷机软件。2、接下来是BIOS准备阶段,用户可以选择从现有显卡提...

自动关机怎么设置win10指令(win10设置自动关机代码)

1最简单的方法是通过系统自带的计划任务来设置自动开关机。2打开‘任务计划程序’,选择‘创建基本任务’,按照提示完成设置,可以选择定时执行或在特定条件下执行。3另外也可以通过第三方软件来实现自动开...