2022-05-27:现在有N条鱼,每条鱼的体积为Ai,从左到右排列,数组arr给出。 每一轮,左边的大鱼一定会吃掉右边比自己小的第一条鱼, 并且每条鱼吃比自己小的鱼的事件是同时发生的。 返回多少轮之

本文主要是介绍2022-05-27:现在有N条鱼,每条鱼的体积为Ai,从左到右排列,数组arr给出。 每一轮,左边的大鱼一定会吃掉右边比自己小的第一条鱼, 并且每条鱼吃比自己小的鱼的事件是同时发生的。 返回多少轮之,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

2022-05-27:现在有N条鱼,每条鱼的体积为Ai,从左到右排列,数组arr给出。
每一轮,左边的大鱼一定会吃掉右边比自己小的第一条鱼,
并且每条鱼吃比自己小的鱼的事件是同时发生的。
返回多少轮之后,鱼的数量会稳定。
注意:6 6 3 3。
第一轮过后 :
对于两个6来说,右边比自己小的第一条鱼都是第1个3,所以只有这个3被吃掉,
数组变成 : 6 6 3(第2个3),
第二轮过后 : 6 6。
返回2。
来自bilibili。

答案2022-05-27:

单调栈。

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

use rand::Rng;
fn main() {let len: i32 = 50;let value: i32 = 20;let test_time: i32 = 20000;println!("测试开始");for _i in 0..test_time {let n: i32 = rand::thread_rng().gen_range(0, len) + 1;let mut arr = random_array(n, value);let mut arr2 = arr.clone();let ans1 = min_turns1(&mut arr);let ans2 = min_turns2(&mut arr2);if ans1 != ans2 {println!("出错了!");print!("arr = {:?}", arr);println!("");println!("ans1 = {}", ans1);println!("ans2 = {}", ans2);break;}}println!("测试结束");
}fn min_turns1(arr: &mut Vec<i32>) -> i32 {let mut ans: i32 = 0;loop {let rest = eat_rest(arr);if arr.len() == rest.len() {break;}*arr = rest;ans += 1;}return ans;
}fn eat_rest(arr: &mut Vec<i32>) -> Vec<i32> {if arr.len() == 0 {return vec![0];}let n = arr.len() as i32;let mut delete: Vec<bool> = vec![];for _i in 0..n {delete.push(false);}let mut len = n;for i in 0..n {for j in i + 1..n {if arr[i as usize] > arr[j as usize] {if !delete[j as usize] {delete[j as usize] = true;len -= 1;}break;}}}let mut rest: Vec<i32> = vec![];for _i in 0..len {rest.push(0);}let mut j: i32 = 0;for i in 0..n {if !delete[i as usize] {rest[j as usize] = arr[i as usize];j += 1;}}return rest;
}fn min_turns2(arr: &mut Vec<i32>) -> i32 {let n = arr.len() as i32;let mut stack: Vec<Vec<i32>> = vec![];for i in 0..n {stack.push(vec![]);for _j in 0..2 {stack[i as usize].push(0);}}let mut stack_size: i32 = 0;let mut ans = 0;let mut i = n - 1;while i >= 0 {let mut cur_ans = 0;while stack_size > 0 && stack[(stack_size - 1) as usize][0] < arr[i as usize] {stack_size -= 1;cur_ans = get_max(cur_ans + 1, stack[stack_size as usize][1]);}stack[stack_size as usize][0] = arr[i as usize];stack[stack_size as usize][1] = cur_ans;stack_size += 1;ans = get_max(ans, cur_ans);i -= 1;}return ans;
}fn get_max<T: Clone + Copy + std::cmp::PartialOrd>(a: T, b: T) -> T {if a > b {a} else {b}
}// 为了测试
fn random_array(n: i32, v: i32) -> Vec<i32> {let mut arr: Vec<i32> = vec![];for _i in 0..n {arr.push(rand::thread_rng().gen_range(0, v) - rand::thread_rng().gen_range(0, v));}return arr;
}

执行结果如下:

在这里插入图片描述


左神java代码

这篇关于2022-05-27:现在有N条鱼,每条鱼的体积为Ai,从左到右排列,数组arr给出。 每一轮,左边的大鱼一定会吃掉右边比自己小的第一条鱼, 并且每条鱼吃比自己小的鱼的事件是同时发生的。 返回多少轮之的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/356249

相关文章

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

Java+AI驱动实现PDF文件数据提取与解析

《Java+AI驱动实现PDF文件数据提取与解析》本文将和大家分享一套基于AI的体检报告智能评估方案,详细介绍从PDF上传、内容提取到AI分析、数据存储的全流程自动化实现方法,感兴趣的可以了解下... 目录一、核心流程:从上传到评估的完整链路二、第一步:解析 PDF,提取体检报告内容1. 引入依赖2. 封装

Java中数组与栈和堆之间的关系说明

《Java中数组与栈和堆之间的关系说明》文章讲解了Java数组的初始化方式、内存存储机制、引用传递特性及遍历、排序、拷贝技巧,强调引用数据类型方法调用时形参可能修改实参,但需注意引用指向单一对象的特性... 目录Java中数组与栈和堆的关系遍历数组接下来是一些编程小技巧总结Java中数组与栈和堆的关系关于

Django HTTPResponse响应体中返回openpyxl生成的文件过程

《DjangoHTTPResponse响应体中返回openpyxl生成的文件过程》Django返回文件流时需通过Content-Disposition头指定编码后的文件名,使用openpyxl的sa... 目录Django返回文件流时使用指定文件名Django HTTPResponse响应体中返回openp

Spring AI使用tool Calling和MCP的示例详解

《SpringAI使用toolCalling和MCP的示例详解》SpringAI1.0.0.M6引入ToolCalling与MCP协议,提升AI与工具交互的扩展性与标准化,支持信息检索、行动执行等... 目录深入探索 Spring AI聊天接口示例Function CallingMCPSTDIOSSE结束语

三频BE12000国补到手2549元! ROG 魔盒Pro WIFI7电竞AI路由器上架

《三频BE12000国补到手2549元!ROG魔盒ProWIFI7电竞AI路由器上架》近日,华硕带来了ROG魔盒ProWIFI7电竞AI路由器(ROGSTRIXGR7Pro),目前新... 华硕推出了ROG 魔盒Pro WIFI7电竞AI路由器(ROG STRIX GR7 Phttp://www.cppcn

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方