牛客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++ Primer 标准库vector示例详解

《C++Primer标准库vector示例详解》该文章主要介绍了C++标准库中的vector类型,包括其定义、初始化、成员函数以及常见操作,文章详细解释了如何使用vector来存储和操作对象集合,... 目录3.3标准库Vector定义和初始化vector对象通列表初始化vector对象创建指定数量的元素值

使用Java发送邮件到QQ邮箱的完整指南

《使用Java发送邮件到QQ邮箱的完整指南》在现代软件开发中,邮件发送功能是一个常见的需求,无论是用户注册验证、密码重置,还是系统通知,邮件都是一种重要的通信方式,本文将详细介绍如何使用Java编写程... 目录引言1. 准备工作1.1 获取QQ邮箱的SMTP授权码1.2 添加JavaMail依赖2. 实现

Java嵌套for循环优化方案分享

《Java嵌套for循环优化方案分享》介绍了Java中嵌套for循环的优化方法,包括减少循环次数、合并循环、使用更高效的数据结构、并行处理、预处理和缓存、算法优化、尽量减少对象创建以及本地变量优化,通... 目录Java 嵌套 for 循环优化方案1. 减少循环次数2. 合并循环3. 使用更高效的数据结构4

java两个List的交集,并集方式

《java两个List的交集,并集方式》文章主要介绍了Java中两个List的交集和并集的处理方法,推荐使用Apache的CollectionUtils工具类,因为它简单且不会改变原有集合,同时,文章... 目录Java两个List的交集,并集方法一方法二方法三总结java两个List的交集,并集方法一

Spring AI集成DeepSeek三步搞定Java智能应用的详细过程

《SpringAI集成DeepSeek三步搞定Java智能应用的详细过程》本文介绍了如何使用SpringAI集成DeepSeek,一个国内顶尖的多模态大模型,SpringAI提供了一套统一的接口,简... 目录DeepSeek 介绍Spring AI 是什么?Spring AI 的主要功能包括1、环境准备2

Spring AI集成DeepSeek实现流式输出的操作方法

《SpringAI集成DeepSeek实现流式输出的操作方法》本文介绍了如何在SpringBoot中使用Sse(Server-SentEvents)技术实现流式输出,后端使用SpringMVC中的S... 目录一、后端代码二、前端代码三、运行项目小天有话说题外话参考资料前面一篇文章我们实现了《Spring

Spring AI与DeepSeek实战一之快速打造智能对话应用

《SpringAI与DeepSeek实战一之快速打造智能对话应用》本文详细介绍了如何通过SpringAI框架集成DeepSeek大模型,实现普通对话和流式对话功能,步骤包括申请API-KEY、项目搭... 目录一、概述二、申请DeepSeek的API-KEY三、项目搭建3.1. 开发环境要求3.2. mav

Springboot的自动配置是什么及注意事项

《Springboot的自动配置是什么及注意事项》SpringBoot的自动配置(Auto-configuration)是指框架根据项目的依赖和应用程序的环境自动配置Spring应用上下文中的Bean... 目录核心概念:自动配置的关键特点:自动配置工作原理:示例:需要注意的点1.默认配置可能不适合所有场景

使用Apache POI在Java中实现Excel单元格的合并

《使用ApachePOI在Java中实现Excel单元格的合并》在日常工作中,Excel是一个不可或缺的工具,尤其是在处理大量数据时,本文将介绍如何使用ApachePOI库在Java中实现Excel... 目录工具类介绍工具类代码调用示例依赖配置总结在日常工作中,Excel 是一个不可或缺的工http://

Java8需要知道的4个函数式接口简单教程

《Java8需要知道的4个函数式接口简单教程》:本文主要介绍Java8中引入的函数式接口,包括Consumer、Supplier、Predicate和Function,以及它们的用法和特点,文中... 目录什么是函数是接口?Consumer接口定义核心特点注意事项常见用法1.基本用法2.结合andThen链