1.合唱队形

Problem: 1.合唱队形

文章目录

  • 思路
  • 解题方法
  • 复杂度
  • Code

思路

这是一个动态规划问题。我们可以通过两次动态规划来解决这个问题。首先,我们从左到右进行动态规划,计算出每个位置的最长递增子序列长度。然后,我们从右到左进行动态规划,计算出每个位置的最长递减子序列长度。最后,我们遍历每个位置,找出最长递增子序列长度和最长递减子序列长度之和最大的位置,这个位置就是合唱队形的中心位置。然后,我们计算出需要出列的同学数量,即总人数减去最长递增子序列长度和最长递减子序列长度之和再加一。

解题方法

1、初始化两个数组,一个用来存储从左到右的最长递增子序列长度,一个用来存储从右到左的最长递减子序列长度。
2、从左到右进行动态规划,计算出每个位置的最长递增子序列长度。
3、从右到左进行动态规划,计算出每个位置的最长递减子序列长度。
4、遍历每个位置,找出最长递增子序列长度和最长递减子序列长度之和最大的位置。
5、计算出需要出列的同学数量,即总人数减去最长递增子序列长度和最长递减子序列长度之和再加一。

复杂度

时间复杂度:

这个算法的时间复杂度是 O ( n 2 ) O(n^2) O(n2),因为我们需要进行两次动态规划,每次动态规划的时间复杂度都是 O ( n 2 ) O(n^2) O(n2)

空间复杂度:

这个算法的空间复杂度是 O ( n ) O(n) O(n),因为我们需要存储两个长度为n的数组。

Code


import java.util.*;
import java.io.*;
// 1:无需package
// 2: 类名必须Main, 不可修改public class Main {static BufferedReader in = new BufferedReader(new InputStreamReader(System.in));static PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out));static StreamTokenizer sr = new StreamTokenizer(in);static int n;static int MAXN = 110;static int[] arr = new int[MAXN];static int[] dpl = new int[MAXN];static int[] dpr = new int[MAXN];public static void main(String[] args) throws IOException {n = nextInt();for(int i = 1; i <= n; i++) {arr[i] = nextInt();}for(int i = 1; i <= n; i++) {dpl[i] = 1;for(int j = 1; j < i; j++) {if(arr[i] > arr[j]) dpl[i] = Math.max(dpl[i], dpl[j] + 1);}}for(int i = n; i >= 1; i--) {dpr[i] = 1;for(int j = i + 1; j <= n; j++) {if(arr[i] > arr[j]) dpr[i] = Math.max(dpr[i], dpr[j] + 1);}}int ans = n;for(int i = 1; i <= n; i++) {ans = Math.min(ans, n - (dpl[i] + dpr[i] - 1));}out.println(ans);out.flush();}static int nextInt() throws IOException {sr.nextToken();return (int)sr.nval;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/682594.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2024幻兽帕鲁服务器创建教程_阿里PK腾讯超简单

幻兽帕鲁官方服务器不稳定&#xff1f;自己搭建幻兽帕鲁服务器&#xff0c;低延迟、稳定不卡&#xff0c;目前阿里云和腾讯云均推出幻兽帕鲁专用服务器&#xff0c;腾讯云直接提供幻兽帕鲁镜像系统&#xff0c;阿里云通过计算巢服务&#xff0c;均可以一键部署&#xff0c;鼠标…

vscode 提取扩展时出错。XHR failed

检查 vscode 设置中的代理服务器&#xff0c;位置如下图 清空 vocode 中的 Proxy&#xff0c;我黄线框的部分&#xff0c;内容清空。 检查电脑系统环境变量&#xff0c;是否设置了 http_proxy 和 https_proxy&#xff0c;如果有设置&#xff0c;则删除这两项&#xff0c;下载完…

leetcode 102.二叉树的层序遍历

这道题讲的就是对于树的数据结构的考察&#xff0c;这里用了一个比较常用的容器就是队列。 思路&#xff1a;首先我们知道&#xff0c;层序遍历也就是广度优先遍历的一种变形而已&#xff0c;既然我们知道广度优先搜索&#xff0c;就应该知道用队列进行辅助输出。 当根节点是…

树莓派4B(Raspberry Pi 4B)使用docker搭建nacos集群

树莓派4B&#xff08;Raspberry Pi 4B&#xff09;使用docker搭建nacos集群 由于国内访问不了docker hub&#xff0c;我选用的国内适配树莓派ARM架构的nacos镜像——centralx/nacos-server。本文涉及到docker compose和docker network方面的知识&#xff0c;基于nacos 2.0.4&am…

《区块链公链数据分析简易速速上手小册》第4章:交易数据分析(2024 最新版)

文章目录 4.1 解析交易输入和输出4.1.1 基础知识4.1.2 重点案例&#xff1a;追踪比特币交易4.1.3 拓展案例 1&#xff1a;以太坊交易的输入输出解析拓展案例1&#xff1a;以太坊交易的输入输出解析步骤1: 连接到以太坊网络步骤2: 获取交易数据步骤3: 解析交易输入结论 4.1.4 拓…

LLM大模型相关问题汇总---包括问题与答案

一、基础篇 1. 目前主流的开源模型体系有哪些&#xff1f; - Transformer体系&#xff1a;由Google提出的Transformer模型及其变体&#xff0c;如BERT、GPT等。 - PyTorch Lightning&#xff1a;一个基于PyTorch的轻量级深度学习框架&#xff0c;用于快速原型设计和实验…

Uipath 调用Python 脚本程序详解

Python 活动概述 UiPath.Python.Activities 是一个新的活动包&#xff0c;创建它是为了支持直接从工作流运行 Python 脚本和方法。 其包含以下活动&#xff1a; Python 作用域(Python Scope) - 为 Python 活动提供作用域的容器。 加载 Python 脚本(Load Python Script) - 将 P…

A股上市以来涨幅排行榜

一、统计数据说明 1. 涨幅排行榜是根据股价的后复权价格计算的&#xff0c;该价格考虑了分红送股拆股等事件对股价的影响&#xff0c;相当于是分红再投资的股价。 2. 年化投资收益率&#xff0c;是根据IPO收盘价至今涨幅计算的复合年化收益率。例如&#xff0c;假设一个股票上…

中国电子学会2023年12月份青少年软件编程Scratch图形化等级考试试卷四级真题(含答案)

2023-12 Scratch四级真题 分数&#xff1a;100 题数&#xff1a;24 分数&#xff1a;60min 一、单选题(共10题&#xff0c;共30分) 1.运行下列程序&#xff0c;输入“abcdef”&#xff0c;程序结束后&#xff0c;变量“字符串”是&#xff1f;&#xff08;B&#xff09;(3…

代码随想录刷题笔记 DAY 26 | 组合总和 No.39 | 组合求和 II No.40 | 分割回文串 No.131

文章目录 Day 2501. 组合总和&#xff08;No. 39&#xff09;1.1 题目1.2 笔记1.3 代码 02. 组合求和 II&#xff08;No. 40&#xff09;2.1 题目2.2 笔记2.3 代码 03. 分割回文串&#xff08;No. 131&#xff09;3.1 题目3.2 笔记3.3 代码 Day 25 01. 组合总和&#xff08;No…

re:从0开始的CSS之旅 16. 高度塌陷问题

1. 高度塌陷问题 高度塌陷问题&#xff1a;在文档流中&#xff0c;父元素的高度默认是被子元素撑开的&#xff0c;子元素多高&#xff0c;父元素就多高。 但是当子元素设置浮动后&#xff0c;我们发现子元素在页面中的位置没变&#xff0c;但是父元素的高度却塌陷了&#xff0…

使用Xdisplay将ipad作为扩展显示器Agent闪退问题

1. 正常流程贴子挺多&#xff0c;可以参考这几篇 https://blog.csdn.net/Shi_Xueqing/article/details/129744496 如何将ipad作为win10的扩展屏&#xff08;使用USB线连接&#xff09;_ipad win usb 上网-CSDN博客 2.在进行pc端软件设置的时候发生闪退 解决方法&#xff1a…

Java入门高频考查基础知识9(银盛15问万字参考答案)

JAVA刷题专栏&#xff1a;http://t.csdnimg.cn/9qscL 目录 一、Springcloud的工作原理 三、注册中心心跳是几秒 四、消费者是如何发现服务提供者的 五、多个消费者调⽤用同⼀接口&#xff0c;eruka默认的分配⽅式是什么 六、springboot常用注解&#xff0c;及其实现 七、…

【算法】字符串匹配算法

文章目录 一、字符串匹配1. KMP2. 字符串哈希 一、字符串匹配 记&#xff1a;主串 s s s 长度为 m m m&#xff0c;子串 p p p 长度为 n n n。 1. KMP 暴力的做法&#xff0c;是在当前字符不匹配的时候&#xff0c;主串和子串都回溯&#xff0c;这样做显然是 O ( n m )…

使用R语言glmnet包进行正则化lasso回归

正则化的原理是尽可能多的将数据中的特征塞进最终模型&#xff0c;特征越多越可以更好地解释数据集的错综复杂。在应用正则化后&#xff0c;每个特征对模型部分的解释程度可能完全不同。通过使用正则化可以减少数据集的噪声&#xff0c;这些噪声可能来对最终模型几乎没有形象的…

苍穹外卖启动!

快捷键 Alt Enter&#xff1a;代码补全 ctrl 左键&#xff1a;进入这个方法 401 令牌校验出问题了&#xff0c;因为token过期了&#xff0c;在yml文件里设置的有效时间&#xff0c;过期之后&#xff0c;员工登陆&#xff0c;重新发送一下数据&#xff0c;获取新的token令牌…

车载常见概念

常见概念 ADAS&#xff08;Advanced Driver Assistance Systems&#xff09;是指先进驾驶辅助系统&#xff0c;是指车辆上装备的一系列技术&#xff0c;旨在提高驾驶员的安全性和驾驶舒适度。下面是ADAS中常见的名称和其英文全称和含义&#xff1a; LDWS&#xff08;Lane Depa…

ClickHouse--10--临时表、视图

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 1.临时表1.1 特征1.2 创建一个临时表 2.视图2.1 普通视图2.2 物化视图 1.临时表 1.1 特征 ClickHouse 支持临时表&#xff0c;临时表具备以下特征&#xff1a; 当…

bat通过ssh增量同步文件夹

要通过 SSH 使用批处理文件&#xff08;.bat&#xff09;进行文件夹的增量同步&#xff0c;你可以使用 rsync 命令&#xff0c;这是一个非常强大的文件同步工具&#xff0c;它支持增量同步。以下是一个简单的批处理脚本示例&#xff0c;该脚本使用 SSH 连接到一个远程服务器&am…

【JAVA WEB】JavaScript(WebAPI)--DOM基本概念 获取元素 点击事件 键盘事件

目录 什么是WebAPI DOM的基本概念 DOM是什么 DOM树 获取元素 querySelector querySelectorAll 事件 事件初识 基本概念 事件三要素 点击事件 键盘事件 什么是WebAPI 前端学习的 JS 分成三个大的部分 ECMAScript&#xff1a;基础语法部分DOM API&#xff1a;操作…