当前位置: 首页 > article >正文

1436:数列分段II -整型二分

1436:数列分段II
题目来源:一本通

在这里插入图片描述
【输入样例】

5 3
4 2 4 5 1

【输出样例】

6

题意

将数列分成若干段,最多M段,求这些段中最大值中的最小值。(M<=N是M的约束)

思路

  • 最大最小问题考虑二分。由于M越大,则每段的平均值越小,即里面的最大值的越小。M作为约束,所以当分段>M作为check()函数跳出条件
  • 题目没给数据范围,所以二分区间可以选择[min(a[i]),max(sum(a[i])](当然,简单点就直接设[0,1e10],不会超时),而M作为约束条件

数据约束

注意事项

哈哈,总有一个样例过不了。检查一下代码,发现有漏洞,始终要清醒:t必须是当前子段和最大值,但当a[i]>t,sum=a[i] 然后进入下一个循环,所以就有Bug。因此需要单独判断a[i],如果>t 就不符合条件。

eg:4 1 4 5 2 很显然有数据5,当Mid=4就不可能成立

参考代码

#include<bits/stdc++.h>
using namespace std;
const int N =1000000; 
int n,m,a[N];
bool check(int t);//判断是否有m段 
int main()
{
	cin>>n>>m;
	int l = 0, r = 0;
	for(int i=0;i<n;i++){
		cin>>a[i];
		l = min(l,a[i]) ;
		r += a[i];
	}
	//二分
	int anwser = 0;
	while(l<=r){
		int mid = (r+l)/2;
		if(check(mid)) {
			anwser = mid;
			r= mid-1; //必须要区间保证是收敛的(不断缩小的) 
		}
		else l = mid+1;
	} 
	cout<<anwser;
   return 0;
}
bool check(int t){
	int sum = 0,ans = 1;//默认为a[0]容易有Bug 万一a[0]>m那就凉凉 
	for(int i=0;i<n;i++){
		if(a[i]>t){ //段里面的单个数据不能超过t否则出错 
			return false;
		}
		sum += a[i];
//		if(t ==5 ) cout<<sum<<"/"<<i<<"   "<<ans<<endl;
		//判断ans的情况,因为ans比m大,说明t可以分更小 ,也就是字段和不是最小值 
		if(sum>t){
			//因为t是sum里面的最大值,所以必须保证sum<=t 
			sum = a[i];
			ans++;
		}
		if(ans>m){
		   return false;
		}
	}
	return true;
}

http://www.kler.cn/a/397558.html

相关文章:

  • AtCoder Beginner Contest 380(A-F)
  • linux企业中常用NFS、ftp服务
  • 108. UE5 GAS RPG 实现地图名称更新和加载关卡
  • (一)Ubuntu20.04服务器端部署Stable-Diffusion-webui AI绘画环境
  • 利用OpenAI进行测试需求分析——从电商网站需求到测试用例的生成
  • Linux下编译安装Nginx
  • 两行命令搭建深度学习环境(Docker/torch2.5.1+cu118/命令行美化+插件),含完整的 Docker 安装步骤
  • 护眼模式浓度调整到最低
  • 【软件测试】一个简单的自动化Java程序编写
  • ELMo模型介绍:深度理解语言模型的嵌入艺术
  • Java基础——网络编程
  • 魔方和群论
  • java 数组 拼接 详解
  • SpringBoot集成热部署
  • 1.7 JS性能优化
  • 黑盒测试案例设计方法的使用(1)
  • 【项目开发】Web App vs Native App,开发者作何选择?
  • 【CVPR2024】2024年CVPR的3D 目标检测的综述(还在补充中)
  • Java 异常处理
  • 31.3 XOR压缩和相关的prometheus源码解读
  • MySQL的编程语言
  • 鸿蒙 管理应用拥有的状态有Localstorage、Appstorage、PersistentStorage、Environment、用户首选项、持久化方案。
  • react项目通过http调用后端springboot服务最简单示例
  • 如何在 Ubuntu 上安装 Emby 媒体服务器
  • 【人工智能】迁移学习在深度学习中的应用:用Python实现自定义数据集图像分类
  • 云原生之运维监控实践-使用Telegraf、Prometheus与Grafana实现对InfluxDB服务的监测