C语言经典算法实例1:求二维数组最大最小值
一、问题描述
求二维数组最大最小值
问题的描述
如下几点所示
- 在n 行 n 列的二维整数数组中,按以下要求选出两个数。
- 首先从每行选出大数,再从选出 的 n 个大数中选出小数;
- 其次,从每行 选出小数,再从选出的 n 个小数中选出大数。
二、算法实例编译环境
本文C语言经典算法实例的编译环境,使用的是集成开发环境:Visual Studio 2019
Visual Studio 2019官网链接如下
Visual Studio 2019集成的开发环境的特点有
-
- Visual Studio 2019默认安装Live Share代码协作服务。
-
- 帮助用户快速编写代码的新欢迎窗口、改进搜索功能、总体性能改进。
-
- Visual Studio IntelliCode AI帮助。
-
- 更好的Python虚拟和Conda支持。
-
- 以及对包括WinForms和WPF在内的.NET Core 3.0项目支持等
三、算法实例实现过程
3.1、包含头文件
包含头文件 代码如下所示
#include <stdio.h>
#include <stdlib.h>
- 将要用到的C语言头文件包含近年来。
3.2、定义宏和声明数组
定义宏和声明数组 代码如下所示
#define MAXN 20
int a[MAXN][MAXN];
- 定义了MAXN ,代表了MAXN为常数20。
- 声明了数组a。
3.3、声明相关变量
声明相关变量 代码如下所示
int min, max;
int row, col, n;
- 声明相关变量min, max,row, col, n;
3.3、输入数组(方阵)的阶
输入数组(方阵)的阶 代码如下所示
printf("Please input the order of the matrix:");/* 输入方阵的阶次 */
scanf("%d", &n);
printf("\nPlease input the elements of the matrix,\nfrom a[0][0] to a[%d][%d]:\n", n - 1, n - 1);
for (row = 0; row < n; row++)
{
for (col = 0; col < n; col++)
{
scanf("%d", &a[row][col]);
}
}
- 根据文字提示,输入数组(方阵)的阶。
- 根据文字提示,向数组中输入数据。
3.4、输出 “输入的数组”
输出 “输入的数组” 代码如下所示
printf("\nThe original matrix is\n");
for