牛客NC406 最长山脉【中等 穷举,动态规划 C++/Java/Go/PHP】

2024-04-27 07:04

本文主要是介绍牛客NC406 最长山脉【中等 穷举,动态规划 C++/Java/Go/PHP】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目

在这里插入图片描述
题目链接:
https://www.nowcoder.com/practice/f4e974a50eda429fbf36515a4197b148

思路

在这里插入图片描述

参考答案C++

class Solution {public:/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可*** @param nums int整型vector* @return int整型*/int longestmountain(vector<int>& nums) {//枚举每个山顶,动态规划if (nums.size() < 3) return 0;int n = nums.size();int left[n];int right[n];for (int i = 0; i < n; i++) {left[i] = 1;if (i > 0 && nums[i] > nums[i - 1]) {left[i] = left[i - 1] + 1;}}for (int i = n - 1; i >= 0; i--) {right[i] = 1;if (i < n - 2 && nums[i] > nums[i + 1]) {right[i] = right[i + 1] + 1;}}int ans = 0;for (int i = 0; i < n; i++) {if (left[i] > 1 && right[i] > 1) {int cur = left[i] + right[i] - 1;if (cur > ans) {ans = cur;}}}return ans;}
};

参考答案Java

import java.util.*;public class Solution {/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可*** @param nums int整型ArrayList* @return int整型*/public int longestmountain (ArrayList<Integer> nums) {//枚举每个山顶,动态规划if (nums == null || nums.size() < 3) return 0;int n = nums.size();int[] left = new int[n];int[] right = new int[n];for (int i = 0; i < n; i++) {left[i] = 1;if (i > 0 && nums.get(i) > nums.get(i - 1)) {left[i] = left[i - 1] + 1;}}for (int i = n - 1; i >= 0 ; i--) {right[i] = 1;if (i < n - 2 && nums.get(i) > nums.get(i + 1)) {right[i] = right[i + 1] + 1;}}int ans = 0x80000000;for (int i = 0; i < n ; i++) {if (left[i] > 1 && right[i] > 1) {int cur = right[i] + left[i] - 1;if (cur > ans) {ans = cur;}}}if (ans == 0x80000000) return 0;return ans;}
}

参考答案Go

package main//import "fmt"/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可*** @param nums int整型一维数组* @return int整型*/
func longestmountain(nums []int) int {//枚举每个山顶,动态规划if nums == nil || len(nums) < 3 {return 0}n := len(nums)left := make([]int, n)right := make([]int, n)for i := 0; i < n; i++ {left[i] = 1if i > 0 && nums[i] > nums[i-1] {left[i] = left[i-1] + 1}}for i := n - 1; i >= 0; i-- {right[i] = 1if i < n-2 && nums[i] > nums[i+1] {right[i] = right[i+1] + 1}}ans := 0for i := 0; i < n; i++ {if left[i] > 1 && right[i] > 1 {cur := left[i] + right[i] - 1if cur > ans {ans = cur}}}return ans
}

参考答案PHP

<?php/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param nums int整型一维数组 * @return int整型*/
function longestmountain( $nums )
{//枚举每个山顶,动态规划if($nums ==null || count($nums) <3)return 0;$n  = count($nums);$left = [];$right=[];for($i=0;$i<$n;$i++){$left[$i] =1;if($i>0 && $nums[$i] > $nums[$i-1]){$left[$i] = $left[$i-1]+1;}}for($i=$n-1;$i>=0;$i--){$right[$i] =1;if($i<$n-2 && $nums[$i]>$nums[$i+1]){$right[$i]=$right[$i+1]+1;}}$ans = 0;for($i=0;$i<$n;$i++){if($left[$i] >1 && $right[$i] >1) {$cur = $left[$i]+$right[$i]-1;if($cur > $ans){$ans = $cur;}}}return $ans;
}

这篇关于牛客NC406 最长山脉【中等 穷举,动态规划 C++/Java/Go/PHP】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++中初始化二维数组的几种常见方法

《C++中初始化二维数组的几种常见方法》本文详细介绍了在C++中初始化二维数组的不同方式,包括静态初始化、循环、全部为零、部分初始化、std::array和std::vector,以及std::vec... 目录1. 静态初始化2. 使用循环初始化3. 全部初始化为零4. 部分初始化5. 使用 std::a

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

SpringBoot条件注解核心作用与使用场景详解

《SpringBoot条件注解核心作用与使用场景详解》SpringBoot的条件注解为开发者提供了强大的动态配置能力,理解其原理和适用场景是构建灵活、可扩展应用的关键,本文将系统梳理所有常用的条件注... 目录引言一、条件注解的核心机制二、SpringBoot内置条件注解详解1、@ConditionalOn

通过Spring层面进行事务回滚的实现

《通过Spring层面进行事务回滚的实现》本文主要介绍了通过Spring层面进行事务回滚的实现,包括声明式事务和编程式事务,具有一定的参考价值,感兴趣的可以了解一下... 目录声明式事务回滚:1. 基础注解配置2. 指定回滚异常类型3. ​不回滚特殊场景编程式事务回滚:1. ​使用 TransactionT

Spring LDAP目录服务的使用示例

《SpringLDAP目录服务的使用示例》本文主要介绍了SpringLDAP目录服务的使用示例... 目录引言一、Spring LDAP基础二、LdapTemplate详解三、LDAP对象映射四、基本LDAP操作4.1 查询操作4.2 添加操作4.3 修改操作4.4 删除操作五、认证与授权六、高级特性与最佳

Spring Shell 命令行实现交互式Shell应用开发

《SpringShell命令行实现交互式Shell应用开发》本文主要介绍了SpringShell命令行实现交互式Shell应用开发,能够帮助开发者快速构建功能丰富的命令行应用程序,具有一定的参考价... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定义S

SpringSecurity JWT基于令牌的无状态认证实现

《SpringSecurityJWT基于令牌的无状态认证实现》SpringSecurity中实现基于JWT的无状态认证是一种常见的做法,本文就来介绍一下SpringSecurityJWT基于令牌的无... 目录引言一、JWT基本原理与结构二、Spring Security JWT依赖配置三、JWT令牌生成与

Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码

《Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码》:本文主要介绍Java中日期时间转换的多种方法,包括将Date转换为LocalD... 目录一、Date转LocalDateTime二、Date转LocalDate三、LocalDateTim