洛谷 P1182 数列分段 Section II ((Java)

洛谷 P1182 数列分段 Section II ((Java)

传送门:P1182 数列分段 Section II

题目:数列分段 Section II

题目描述

对于给定的一个长度为N的正整数数列 A 1 ∼ N A_{1\sim N} A1N,现要将其分成 M M M M ≤ N M\leq N MN)段,并要求每段连续,且每段和的最大值最小。

关于最大值最小:

例如一数列 4 2 4 5 1 4\ 2\ 4\ 5\ 1 4 2 4 5 1 要分成 3 3 3 段。

将其如下分段:

[ 4 2 ] [ 4 5 ] [ 1 ] [4\ 2][4\ 5][1] [4 2][4 5][1]

第一段和为 6 6 6,第 2 2 2 段和为 9 9 9,第 3 3 3 段和为 1 1 1,和最大值为 9 9 9

将其如下分段:

[ 4 ] [ 2 4 ] [ 5 1 ] [4][2\ 4][5\ 1] [4][2 4][5 1]

第一段和为 4 4 4,第 2 2 2 段和为 6 6 6,第 3 3 3 段和为 6 6 6,和最大值为 6 6 6

并且无论如何分段,最大值不会小于 6 6 6

所以可以得到要将数列 4 2 4 5 1 4\ 2\ 4\ 5\ 1 4 2 4 5 1 要分成 3 3 3 段,每段和的最大值最小为 6 6 6

输入格式

1 1 1 行包含两个正整数 N , M N,M N,M

2 2 2 行包含 N N N 个空格隔开的非负整数 A i A_i Ai,含义如题目所述。

输出格式

一个正整数,即每段和最大值最小为多少。

样例 #1

样例输入 #1

5 3
4 2 4 5 1

样例输出 #1

6

提示

对于 20 % 20\% 20% 的数据, N ≤ 10 N\leq 10 N10

对于 40 % 40\% 40% 的数据, N ≤ 1000 N\leq 1000 N1000

对于 100 % 100\% 100% 的数据, 1 ≤ N ≤ 1 0 5 1\leq N\leq 10^5 1N105 M ≤ N M\leq N MN A i < 1 0 8 A_i < 10^8 Ai<108, 答案不超过 1 0 9 10^9 109

分析:

题目考察二分搜索,用于找到使得每段和的最大值最小的分段方案中的最小可能值。

具体实现如下:

首先读取输入,包括 n(数列长度)和 m(要分成的段数),以及 n 个数组元素。

初始化左右边界,边界最小为数组中的最大元素,最大为数组元素总和。

使用循环进行二分查找,在每次循环中,计算当前的中间值mid,然后遍历整个数组,累计每一段的和。

如果累计和大于mid,则将累计值等于 a[i],并将切割次数加1。
如果累计值等于mid(即刚好满足一段并且不是最后一段),则将累计值归零,并将切割次数加1。

如果切割次数大于m-1(因为切割次数比总段数少1),则说明当前的mid值太小,需要增加mid,因此更新左边界l为mid+1。
如果切割次数小于等于m-1,则说明当前的mid值足够大,但不一定是最小的满足条件的值,因此更新右边界r为mid-1,并更新答案ans为当前的mid值。

最后输出答案ans,即每段和的最大值最小为多少。

这个算法时间复杂度为O(n logm),其中n为数列长度,m为要分成的段数。

代码:

import java.util.*;
public class Main{public static void main(String[] args) {  Scanner sc = new Scanner(System.in);int n = sc.nextInt();int m = sc.nextInt();int [] a = new int [n+10];// l为左边界,r为右边界int l = 0;int r = (int)1e9;long ans = 0; // 输出答案for(int i = 0;i < n;i++) {a[i] = sc.nextInt();ans += a[i];// 边界最小为数组最大的元素l = Math.max(l, a[i]);}// 边界最大为数组元素之和ans = r = (int) Math.min(r, ans);while(l <= r) {
//    		System.out.printf("l r:%d %d\n",l,r);int mid = (l+r)/2;int t = 0; // 每段的累加值int cnt = 0;//切割的次数for(int i = 0;i < n;i++) {t += a[i];if(t > mid) {t = a[i];cnt++;}else if(t==mid&&i<n-1) {t = 0;cnt++;}}// 切割的次数太多,需要增加切割长度midif(cnt > m-1) {l = mid + 1;}else {// 可能存在更少的切割长度mid,并更新答案ansr = mid -1;ans = mid;}
//    		System.out.printf("cnt mid ans:%d %d %d\n",cnt,mid,ans);}System.out.println(ans);}
}

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

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

相关文章

2024,重新出发

我终于回来了QAQ 上次更系统的文章还是在2022呢&#xff0c;看看之前的文章&#xff0c;6个粉丝就开心得不行&#x1f636; 回首向来萧瑟处&#xff0c;归去&#xff0c;也无风雨也无晴。 其实早在2023就发现自己不怎么更文章了&#xff0c;一直在想更&#xff0c;但就……一直…

【数据结构】13:表达式转换(中缀表达式转成后缀表达式)

思想&#xff1a; 从头到尾依次读取中缀表达式里的每个对象&#xff0c;对不同对象按照不同的情况处理。 如果遇到空格&#xff0c;跳过如果遇到运算数字&#xff0c;直接输出如果遇到左括号&#xff0c;压栈如果遇到右括号&#xff0c;表示括号里的中缀表达式已经扫描完毕&a…

每日一练:LeeCode-654、最大二叉树【二叉树+DFS+分治】

本文是力扣LeeCode-654、最大二叉树【二叉树DFS分治】 学习与理解过程&#xff0c;本文仅做学习之用&#xff0c;对本题感兴趣的小伙伴可以出门左拐LeeCode。 给定一个不重复的整数数组 nums 。 最大二叉树 可以用下面的算法从 nums 递归地构建: 创建一个根节点&#xff0c;其…

python安装cv2失败

问题:安装cv2包失败 解决方法&#xff1a; pip install opencv-python或在Anaconda中conda install opencv-python

你好,C++(11)如何用string数据类型表示一串文字?根据初始值自动推断数据类型的auto关键字(C++ 11)

你好&#xff0c;C&#xff08;11&#xff09;如何用string数据类型表示一串文字&#xff1f;根据初始值自动推断数据类型的auto关键字&#xff08;&#xff23; 11&#xff09; 3.5.2 字符串类型 使用char类型的变量我们可以表示单个字符&#xff0c;那么&#xff0c;我们又…

蓝牙BLE学习-蓝牙广播

1.概念 什么叫做广播&#xff0c;顾名思义就像广场上的大喇叭一样&#xff0c;不停的向外传输着信号。不同的是&#xff0c;大喇叭传输的是音频信号&#xff0c;而蓝牙传输的是射频信号。 BLE使用的是无线电波传递信息&#xff0c;就是将数据编码&#xff0c;调制到射频信号中发…

C语言——oj刷题——模拟实现库函数strlen

目录 方法一&#xff1a;迭代法 方法二&#xff1a;递归法 方法三&#xff1a;指针算术法 方法四&#xff1a;汇编指令法 当我们使用C语言进行字符串操作时&#xff0c;经常会用到库函数strlen来获取字符串的长度。strlen函数的作用是计算一个以null字符结尾的字符串的长度…

六、java高级-泛型(一)

六、泛型 1、泛型 从什么是泛型、泛型从何而来、泛型出现是为了解决什么问题、功能及作用说泛型 1.1什么是泛型&#xff1f; 泛型&#xff1a;即“参数化类型”&#xff0c;也就是将需要操作对象的类型进行参数化。在编写代码的时候&#xff0c;不必声明操作对象&#xff08;…

docker从入门到入土

docker到底是什么&#xff1f; docker是世界领先的软件容器平台&#xff0c;基于GO语言进行开发实现docker能够自动执行重复性任务&#xff0c;例如搭建和配置开发环境&#xff0c;从而解放开发人员用户可以方便地创建和使用容器&#xff0c;把自己的应用放入容器&#xff0c;…

基于Robei EDA--实现串口通信

一、串口简介 串口作为常用的三大低速总线&#xff08;UART、SPI、IIC&#xff09;之一&#xff0c;在设计众多通信接口和调试时占有重要地位。但UART和SPI、IIC不同的是&#xff0c;它是异步通信接口&#xff0c;异步通信中的接收方并不知道数据什么时候会到达&#xff0c;所…

int VS Integer

在Java中&#xff0c;int 是一种基本数据类型&#xff08;primitive type&#xff09;&#xff0c;而 Integer 是 int 的包装类&#xff08;wrapper class&#xff09;。它们之间的主要区别在于以下几点&#xff1a; 数据类型&#xff1a;int 是基本的整数类型&#xff0c;它在…

Linux gzip命令教程:如何有效地压缩和解压文件(附实例详解和注意事项)

Linux gzip命令介绍 gzip&#xff08;GNU zip&#xff09;是一种在Linux系统中常见的命令行压缩工具。它使用DEFLATE压缩算法来减小文件的大小&#xff0c;使文件更易于存储和传输。gzip主要用于压缩文本文件、Tar归档文件和网页。不建议使用gzip来压缩图像、音频、PDF文档和其…

【P1506 拯救oibh总部】

拯救oibh总部 题目背景 oibh 总部突然被水淹没了&#xff01;现在需要你的救援…… 题目描述 oibh 被突来的洪水淹没了&#xff0c;还好 oibh 总部有在某些重要的地方起一些围墙。用 * 号表示&#xff0c;而一个四面被围墙围住的区域洪水是进不去的。 oibh 总部内部也有许…

【后端高频面试题--SpringBoot篇】

&#x1f680; 作者 &#xff1a;“码上有前” &#x1f680; 文章简介 &#xff1a;后端高频面试题 &#x1f680; 欢迎小伙伴们 点赞&#x1f44d;、收藏⭐、留言&#x1f4ac; 这里写目录标题 1.什么是SpringBoot&#xff1f;它的主要特点是什么&#xff1f;2.列举一些Spri…

《CSS 简易速速上手小册》第4章:视觉美学(2024 最新版)

文章目录 4.1 颜色理论在 CSS 设计中的应用&#xff1a;网页的调色盘4.1.1 基础知识4.1.2 重点案例&#xff1a;创建一个具有情感设计的登录页面4.1.3 拓展案例 1&#xff1a;使用颜色增强信息的可视化表示4.1.4 拓展案例 2&#xff1a;利用颜色创建网站的品牌身份 4.2 字体与文…

JS逆向手记01__前端基础

系列文章目录 系列手记占位 文章目录 系列文章目录前言一、js自执行函数语法二、js变量类型的转换&#xff08;与字符串相加&#xff09;三、浏览器环境&#xff08;BOM&#xff09;四、html渲染环境&#xff08;DOM&#xff09;五、html发起请求&#xff08;表单form&#xf…

书生·浦语大模型第四课作业

基础作业&#xff1a; 构建数据集&#xff0c;使用 XTuner 微调 InternLM-Chat-7B 模型, 让模型学习到它是你的智能小助手&#xff0c;效果如下图所示&#xff0c;本作业训练出来的模型的输出需要将不要葱姜蒜大佬替换成自己名字或昵称&#xff01; 1.安装 # 如果你是在 Int…

Java是如何实现的平台无关?

&#x1f3ac;作者简介&#xff1a;大家好&#xff0c;我是小徐&#x1f947;☁️博客首页&#xff1a;CSDN主页小徐的博客&#x1f304;每日一句&#xff1a;好学而不勤非真好学者 &#x1f4dc; 欢迎大家关注&#xff01; ❤️ 1、什么是平台无关性 平台无关性就是一种语言在…

寒假作业

手写盗版微信登入界面 #include "mainwindow.h" #include "ui_mainwindow.h"MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow) {ui->setupUi(this);this->resize(421,575);this->setFixedSize(421,575);th…

C#系列-C#EF框架实现雪花主键(20)

在C#中&#xff0c;使用Entity Framework (EF) 框架并不直接涉及到主键的生成策略。主键的生成通常是在数据库层面或者在应用程序层面处理的。雪花主键&#xff08;Snowflake ID&#xff09;是一种在分布式系统中生成唯一ID的算法&#xff0c;它通常是由Twitter的雪花算法演变而…