mirror of
https://github.com/renbaoshuo/202401-programming-assignments.git
synced 2024-12-16 15:44:39 +00:00
60 lines
1.3 KiB
Markdown
60 lines
1.3 KiB
Markdown
|
# 6-4 分治法求解金块问题
|
|||
|
|
|||
|
老板有一袋金块(共n块,2≤n≤100),两名最优秀的雇员每人可以得到其中的一块,排名第一的得到最重的金块,排名第二的则得到袋子中最轻的金块。
|
|||
|
|
|||
|
输入一个正整数$$N$$($$2\le N\le 100$$)和$$N$$个整数,用分治法求出最重金块和最轻金块。
|
|||
|
|
|||
|
本题要求实现2个函数,分别使用分治法在数组中找出最大值、最小值。
|
|||
|
|
|||
|
### 函数接口定义:
|
|||
|
```c++
|
|||
|
int max(int a[ ], int m, int n);
|
|||
|
int min(int a[ ], int m, int n);
|
|||
|
```
|
|||
|
递归函数`max`用分治法求出a[m]~a[n]中的最大值并返回。
|
|||
|
|
|||
|
递归函数`min`用分治法求出a[m]~a[n]中的最小值并返回。
|
|||
|
|
|||
|
### 裁判测试程序样例:
|
|||
|
```c++
|
|||
|
#include <stdio.h>
|
|||
|
#define MAXN 101
|
|||
|
|
|||
|
int max(int a[ ], int m, int n);
|
|||
|
int min(int a[ ], int m, int n);
|
|||
|
|
|||
|
int main(void)
|
|||
|
{
|
|||
|
int i, n;
|
|||
|
int a[MAXN];
|
|||
|
|
|||
|
scanf ("%d", &n);
|
|||
|
if(n >= 2 && n <= MAXN-1 ){
|
|||
|
for(i = 0; i < n; i++){
|
|||
|
scanf ("%d", &a[i]);
|
|||
|
}
|
|||
|
printf("max = %d\n", max(a, 0, n-1));
|
|||
|
printf("min = %d\n", min(a, 0, n-1));
|
|||
|
}else{
|
|||
|
printf("Invalid Value.\n");
|
|||
|
}
|
|||
|
|
|||
|
return 0;
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
/* 请在这里填写答案 */
|
|||
|
```
|
|||
|
|
|||
|
### 输入样例:
|
|||
|
```in
|
|||
|
6
|
|||
|
3 9 4 9 2 4
|
|||
|
```
|
|||
|
|
|||
|
### 输出样例:
|
|||
|
```out
|
|||
|
max = 9
|
|||
|
min = 2
|
|||
|
```
|