2022-09-25:给定一个二维数组matrix,数组中的每个元素代表一棵树的高度。
你可以选定连续的若干行组成防风带,防风带每一列的防风高度为这一列的最大值
防风带整体的防风高度为,所有列防风高度的最小值。
比如,假设选定如下三行
1 5 4
7 2 6
2 3 4
1、7、2的列,防风高度为7
5、2、3的列,防风高度为5
4、6、4的列,防风高度为6
防风带整体的防风高度为5,是7、5、6中的最小值
给定一个正数k,k <= matrix的行数,表示可以取连续的k行,这k行一起防风。
求防风带整体的防风高度最大值。

答案2022-09-25:

窗口内最大值和最小值问题。

代码用rust编写。代码如下:

use rand::Rng;
use std::iter::repeat;
fn main() {
let n_max = 10;
let m_max = 10;
let v_max = 50;
let test_time = 1000;
println!("测试开始");
for _ in 0..test_time {
let n = rand::thread_rng().gen_range(0, n_max) + 1;
let m = rand::thread_rng().gen_range(0, m_max) + 1;
let mut matrix = generate_matrix(n, m, v_max);
let k = rand::thread_rng().gen_range(0, n) + 1;
let ans1 = best_height1(&mut matrix, k);
let ans2 = best_height2(&mut matrix, k);
if ans1 != ans2 {
println!("出错了");
break;
}
}
println!("测试结束");
} const MAX_VALUE: i32 = 1 << 31 - 1; fn best_height1(matrix: &mut Vec<Vec<i32>>, k: i32) -> i32 {
let n = matrix.len() as i32;
let m = matrix[0].len() as i32;
let mut ans = 0;
for start_row in 0..n {
let mut bottle_neck = MAX_VALUE;
for col in 0..m {
let mut height = 0;
let mut end_row = start_row;
while end_row < n && (end_row - start_row + 1 <= k) {
height = get_max(height, matrix[end_row as usize][col as usize]);
end_row += 1;
}
bottle_neck = get_min(bottle_neck, height);
}
ans = get_max(ans, bottle_neck);
}
return ans;
} fn get_max<T: Clone + Copy + std::cmp::PartialOrd>(a: T, b: T) -> T {
if a > b {
a
} else {
b
}
} fn get_min<T: Clone + Copy + std::cmp::PartialOrd>(a: T, b: T) -> T {
if a < b {
a
} else {
b
}
} fn best_height2(matrix: &mut Vec<Vec<i32>>, k: i32) -> i32 {
let n = matrix.len() as i32;
let m = matrix[0].len() as i32;
let mut window_maxs: Vec<Vec<i32>> = repeat(repeat(0).take(n as usize).collect())
.take(m as usize)
.collect(); let mut window_l_r: Vec<Vec<i32>> = repeat(repeat(0).take(2).collect())
.take(m as usize)
.collect();
for i in 0..k {
add_row(matrix, m, i, &mut window_maxs, &mut window_l_r);
}
let mut ans = bottle_neck(matrix, m, &mut window_maxs, &mut window_l_r);
for i in k..n {
add_row(matrix, m, i, &mut window_maxs, &mut window_l_r);
delete_row(m, i - k, &mut window_maxs, &mut window_l_r);
ans = get_max(
ans,
bottle_neck(matrix, m, &mut window_maxs, &mut window_l_r),
);
}
return ans;
} fn add_row(
matrix: &mut Vec<Vec<i32>>,
m: i32,
row: i32,
window_maxs: &mut Vec<Vec<i32>>,
window_l_r: &mut Vec<Vec<i32>>,
) {
for col in 0..m {
while window_l_r[col as usize][0] != window_l_r[col as usize][1]
&& matrix
[window_maxs[col as usize][(window_l_r[col as usize][1] - 1) as usize] as usize]
[col as usize]
<= matrix[row as usize][col as usize]
{
window_l_r[col as usize][1] -= 1;
}
window_maxs[col as usize][window_l_r[col as usize][1] as usize] = row;
window_l_r[col as usize][1] += 1;
}
} fn delete_row(m: i32, row: i32, window_maxs: &mut Vec<Vec<i32>>, window_l_r: &mut Vec<Vec<i32>>) {
for col in 0..m {
if window_maxs[col as usize][window_l_r[col as usize][0] as usize] == row {
window_l_r[col as usize][0] += 1;
}
}
} fn bottle_neck(
matrix: &mut Vec<Vec<i32>>,
m: i32,
window_maxs: &mut Vec<Vec<i32>>,
window_l_r: &mut Vec<Vec<i32>>,
) -> i32 {
let mut ans = MAX_VALUE;
for col in 0..m {
ans = get_min(
ans,
matrix[window_maxs[col as usize][window_l_r[col as usize][0] as usize] as usize]
[col as usize],
);
}
return ans;
} fn generate_matrix(n: i32, m: i32, v: i32) -> Vec<Vec<i32>> {
let mut matrix: Vec<Vec<i32>> = repeat(repeat(0 as i32).take(m as usize).collect())
.take(n as usize)
.collect();
for i in 0..n {
for j in 0..m {
matrix[i as usize][j as usize] = rand::thread_rng().gen_range(0, v) + 1;
}
}
return matrix;
}

执行结果如下:


左神java代码

2022-09-25:给定一个二维数组matrix,数组中的每个元素代表一棵树的高度。 你可以选定连续的若干行组成防风带,防风带每一列的防风高度为这一列的最大值 防风带整体的防风高度为,所有列防风高度的更多相关文章

  1. ytu 1050:写一个函数,使给定的一个二维数组(3×3)转置,即行列互换(水题)

    1050: 写一个函数,使给定的一个二维数组(3×3)转置,即行列互换 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 154  Solved: 112[ ...

  2. c语言题目:找出一个二维数组的“鞍点”,即该位置上的元素在该行上最大,在该列上最小。也可能没有鞍点

    //题目:找出一个二维数组的“鞍点”,即该位置上的元素在该行上最大,在该列上最小.也可能没有鞍点. // #include "stdio.h" #include <stdli ...

  3. [CareerCup] 13.10 Allocate a 2D Array 分配一个二维数组

    13.10 Write a function in C called my2DAlloc which allocates a two-dimensional array. Minimize the n ...

  4. 如何用一个for循环打印出一个二维数组

    思路分析: 二维数组在内存中默认是按照行存储的,比如一个二维数组{{1,2,3,},{4,5,6}},它在内存中存储的顺序就是1.2.3.4.5.6,也就是说,对于这6个数组元素,按照从0到5给它们编 ...

  5. C语言程序,找出一个二维数组的鞍点。

    什么是鞍点????? 鞍点就是在一个二维数组中,某一个数在该行中最大,然而其在该列中又是最小的数,这样的数称为鞍点. 昨天突然在书上看到这样的一道题,就自己尝试着写了一个找出一个二维数组中的鞍点. 好 ...

  6. C#编写程序,找一找一个二维数组中的鞍点

    编写程序,找一找一个二维数组中的鞍点(即该位置上的元素值在行中最大,在该列上最小.有可能数组没有鞍点).要求: 1.二维数组的大小.数组元素的值在运行时输入: 2.程序有友好的提示信息. 代码: us ...

  7. 在主方法中定义一个大小为10*10的二维字符型数组,数组名为y,正反对角线上存的是‘*’,其余 位置存的是‘#’;输出这个数组中的所有元素。

    //在主方法中定义一个大小为10*10的二维字符型数组,数组名为y,正反对角线上存的是‘*’,其余 位置存的是‘#’:输出这个数组中的所有元素. char [][]y=new char [10][10 ...

  8. new一个二维数组

    .定义一个二维数组 char **array1 array1 = new char *[x]; for(i=0;i<x;++i) array1[i] = new char[y]; ...用的时候 ...

  9. poj2155一个二维树状数组

                                                                                                         ...

  10. php中向前台js中传送一个二维数组

    在php中向前台js中传送一个二维数组,并在前台js接收获取其中值的全过程方法: (1),方法说明:现在后台将数组发送到前台 echo json_encode($result); 然后再在js页面中的 ...

随机推荐

  1. ps18.3.20

    PS添加图层蒙版,然后画笔,括号是画笔的大小,,还要调,不透明度

  2. TCP粘包和拆包

    假设客户端分别发送了两个数据包D1和D2给服务器,由于服务器一次读取的字节数是不确定的,故可能存在以下4中情况: 服务端分两次读到了两个独立的数据包D1和D2,没有粘包和拆包 服务端分一次收到两个数据 ...

  3. DVWA-Brute Force(暴力破解)

    暴力破解漏洞,没有对登录框做登录限制,攻击者可以不断的尝试暴力枚举用户名和密码 LOW 审计源码 <?php // 通过GET请求获取Login传参, // isset判断一个变量是否已设置,判 ...

  4. 一篇博客带你学会MyBatis

    概念 MyBatis是一款持久层框架,用于简化JDBC操作(JavaEE三层架构:表现层(用来做页面的代码),业务层(业务逻辑代码),持久层(对数据库操作的代码))(框架就是一个半成品软件,是一套可重 ...

  5. 在CentOS中安装Docker

    概述 Docker是一款使用Golang开发的开源容器引擎,我们可以使用Docker将自己的应用和相关依赖进行打包,实现在不同服务器上进行快速部署,而不需要再更多关注部署环境的差异性.结合kubern ...

  6. 基于声网 Flutter SDK 实现多人视频通话

    前言 本文是由声网社区的开发者"小猿"撰写的Flutter基础教程系列中的第一篇.本文除了讲述实现多人视频通话的过程,还有一些 Flutter 开发方面的知识点.该系列将基于声网 ...

  7. 【git】学习笔记

    一.git原理 git只能跟踪文本文件的变化,比如txt文件.程序代码等.而对于图片.视频等二进制文件的变化,就无法知道变化了哪里. git 分支的理解:如下图所示,git分支可以理解为是一个指针以及 ...

  8. 如何用Python对股票数据进行LSTM神经网络和XGboost机器学习预测分析(附源码和详细步骤),学会的小伙伴们说不定就成为炒股专家一夜暴富了

    前言 最近调研了一下我做的项目受欢迎程度,大数据分析方向竟然排第一,尤其是这两年受疫情影响,大家都非常担心自家公司裁员或倒闭,都想着有没有其他副业搞搞或者炒炒股.投资点理财产品,未雨绸缪,所以不少小伙 ...

  9. computed的setter妙用

    使用场景:当我们用v-model绑定了一个计算属性,想直接设置计算属性时,就要利用到setter demo: <template> <div> <div>First ...

  10. 每日复习——static , 饿汉式方法,懒汉式方法,以及单例设计模式

    1.1.static 的使用 当我们编写一个类时,其实就是在描述其对象的属性和行为,而并没有产生实质上的对象,只有通过 new 关键字才会产生出对象,这时系统才会分配内存空间给对象,其方法才可以供外部 ...