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

分治法——二分答案

有时,直接由问题求得答案十分困难,而已知答案来验证答案正确性则要容易得多,此时可以考虑直接枚举答案。当然,大部分时候直接暴力枚举答案的时间复杂度肯定超出了题目要求,这时我们就可以通过二分答案的方式来加快枚举。

例题1:

D-数列分段 II_Part1.2 基础算法-二分与三分

这题想直接求得答案是很困难的,但是如果我们已知了答案是x,即数列分为M段后,每段和的最大值为x,此时可以通过以下方式验证正确性:

由于分段必须连续,所以我们对数列的第一个数开始一直求和,当在第i个数字求和大于x时,说明i不能被划分到这一段中,所以从i开始向后划分下一段,继续求和,重复以上操作,当划分完所有分段后,如果划分出的分段数大于M,则说明不能在每段和的最大值为x的情况下将数列划分为M段,因为此时,无论你将多出的分段划分到M中的任意一段中,都会导致该分段的和超过x。

那么,本题我们就可以通过二分答案的方式找出x的最小值。根据题意,x的取值范围可以缩小至数列中的最小值到数列的总和,我们在这个范围内二分答案,找出x的最小值。示例代码如下:

# 获取题目输入
N, M = map(int, input().split())
A = list(map(int, input().split()))# 二分答案
left = min(A)
right = sum(A)# 检查和最大值为x时,能否被分为M段
def check(x):sum_current = 0sum_before = 0count = 1for e in A:if e > x:return Falseif sum_current + e - sum_before > x:sum_before = sum_currentsum_current += ecount += 1else:sum_current += eif count > M:return Falsereturn Truewhile left < right:mid = (left + right) >> 1if check(mid):right = midelse:left = mid + 1
print("%d" % left)

例题2:

A-愤怒的牛_Part1.2 基础算法-二分与三分

本题同例题一,当已知了答案是x即牛舍间的距离最小距离为x时,可以通过以下方式验证:

我们对牛舍按位置从小到大排序,按贪心思想,从第一个位置开始放置牛,从下一个位置开始,如果到前一个位置的距离小于x则不能放置牛,只有大于等于x时可以放置牛,按此规则一直尝试到最后一个位置,如果此时放置的牛的数量小于m,则说明不能在牛舍间的距离最小距离为x放置m头牛。

答案的范围在0~牛舍相距最远的距离,在这个范围内二分答案,找出x的最大值。示例代码如下:

# 获取题目输入
import sysinput = sys.stdin.read
data = input().split()
n = int(data[0])
m = int(data[1])
a = list(map(int, data[2:2+n]))
a.sort()  # 升序排序# 二分答案
left = 0
right = a[-1] - a[0]# 最小距离为x时,能否放入m头牛
def check(x):cnt = 0before = 0for i in range(len(a)):if i == 0:cnt += 1continueif a[i] - a[before] >= x:cnt += 1before = ireturn cnt >= mwhile left < right:mid = (left + right + 1) >> 1if check(mid):left = midelse:right = mid - 1
print("%d" % left)

http://www.xdnf.cn/news/19019.html

相关文章:

  • XFile v2 系统架构文档
  • Ansible 核心模块与实操练习
  • 第十三章项目资源管理--13.3 规划资源管理
  • Apifox 8 月更新|新增测试用例、支持自定义请求示例代码、提升导入/导出 OpenAPI/Swagger 数据的兼容性
  • 手写MyBatis第37弹: 深入MyBatis MapperProxy:揭秘SQL命令类型与动态方法调用的完美适配
  • AI赋能前端性能优化:核心技术与实战策略
  • Swift 解法详解 LeetCode 364:嵌套列表加权和 II
  • 713 乘积小于k的子数组
  • git学习 分支管理(branching)合并分支
  • golang13 单元测试
  • Office 2024 长期支持版(Mac中文)Word、Execl、PPT
  • Node.js 多版本管理工具 nvm 的安装与使用教程(含镜像加速与常见坑)
  • 共识算法如何保障网络安全
  • Java全栈开发面试实战:从基础到微服务的深度探索
  • k8s集群Prometheus部署
  • 1 vs 10000:如何用AI智能体与自动化系统,重构传统销售客户管理上限?
  • Wi-Fi数据包发送机制:从物理层到MAC层的深度解析
  • 记录使用ruoyi-flowable开发部署中出现的问题以及解决方法(二)
  • 贴片式TE卡 +北京君正+Rk瑞芯微的应用
  • 直线拟合方法全景解析:最小二乘、正交回归与 RANSAC
  • Transformer实战(15)——使用PyTorch微调Transformer语言模型
  • 了解迁移学习吗?大模型中是怎么运用迁移学习的?
  • 达梦数据库配置文件-COMPATIBLE_MODE
  • 数据结构青铜到王者第七话---队列(Queue)
  • 《websocketpp使用指北》
  • ModuleNotFoundError: No module named ‘dbgpt_app‘
  • Python音频分析与线性回归:探索声音中的数学之美
  • 学习游戏制作记录(存档点和丢失货币的保存以及敌人的货币掉落)8.27
  • 计算机网络——DNS,ARP,RARP,DHCP,ICMP
  • Marin说PCB之包地间距对GMSL2信号阻抗的影响分析--01