您的位置:首页 > 科技 > 能源 > 电子硬件工程师培训机构_南京核酸最新通知_重庆网站开发公司_谷歌seo优化公司

电子硬件工程师培训机构_南京核酸最新通知_重庆网站开发公司_谷歌seo优化公司

2025/5/16 7:51:28 来源:https://blog.csdn.net/weixin_74850661/article/details/146686965  浏览:    关键词:电子硬件工程师培训机构_南京核酸最新通知_重庆网站开发公司_谷歌seo优化公司
电子硬件工程师培训机构_南京核酸最新通知_重庆网站开发公司_谷歌seo优化公司

文章目录

  • 习题
    • 肖恩的n次根
    • 分巧克力
    • 2.卡牌

  • 二分是十分重要的一个算法,常常用于求解一定范围内,找到满足条件的边界值的情况
  • 主要分为浮点数二分整数二分
  • 二分问题,最主要是写出这个check函数,这个check函数最主要就是使用模拟的方法进行求解
    二分查找算法一
    二分算法(二)
    在这里插入图片描述

函数单调

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

0-1单调

在这里插入图片描述
在这里插入图片描述

习题

肖恩的n次根

肖恩的n次根

在这里插入图片描述

  • 这题是一个浮点数二分的问题,我们只用确定区间的左范围和右范围,确定一个精度进行判断,最好是超过题目要求的精度的100
import os
import sys# 请在此输入您的代码
# 浮点数二分法# 判断是否小于等于target
def check(a1,b1,target):ans = 1for i in range(b1):ans *= a1return ans <= targeta,b = map(int,input().split())l,r = 0,1000
while r - l > 1e-9:mid = (l+r)/2if check(mid,b,a):l = mid else:r = midprint(int(r*1000))

分巧克力

分巧克力

在这里插入图片描述

  • 判断是否存在单调性:当你分到的巧克力的边长越长,那么可以切分的巧克力的数量就越少,所以说是存在这个单调性的
  • 那么确定一个二分的范围:最少的边长,肯定是1,最大的边长,那么就可以认为是最长的w,h
import os
import sys# 请在此输入您的代码N,K = map(int,input().split())
cho = []
maxnum = 0
for _ in range(N):h,w = map(int,input().split())maxnum = max(maxnum,h,w)cho.append([h,w])def check(mid):cou = 0for i in range(N):cou += (cho[i][0] // mid )* (cho[i][1] // mid)return cou >= Kl ,r = 1,maxnum
ans = 0 
while l <= r:mid = (l+r) // 2if check(mid):ans = max(ans,mid)l = mid + 1else:r = mid - 1
print(ans)
  • 注意上面的题目,有些同学可能判断不了,最后的答案是l还是r,所以我们直接多开一个变量,当满足情况的时候更新答案即可,最后直接输出这个ans
  • 当然,在理解的情况,我们当然是输出不满足情况下修改的那个变量,在这个题目当中,就是r
import os
import sys# 请在此输入您的代码N,K = map(int,input().split())
cho = []
maxnum = 0
for _ in range(N):h,w = map(int,input().split())maxnum = max(maxnum,h,w)cho.append([h,w])def check(mid):cou = 0for i in range(N):cou += (cho[i][0] // mid )* (cho[i][1] // mid)return cou >= Kl ,r = 1,maxnum
while l <= r:mid = (l+r) // 2if check(mid):l = mid + 1else:r = mid - 1
print(r)

2.卡牌

2.卡牌

在这里插入图片描述

  • 确定二分的对象,那就是对于可以组成的牌的套数,对应的范围0到max(a)+max(b),因为尽可能把最大的情况都得包括进去
  • check函数的确定,就是检查,我们要求组成mid套牌,能否在每一种牌都可以凑出mid张,如果有一种不满足,提前返回False,当然得考虑这个补充的牌的数量是否超过m
import os
import sys# 请在此输入您的代码n,m = map(int,input().split())
a = list(map(int,input().split()))
b = list(map(int,input().split()))def check(mid):needchange = 0for i in range(n):# 模拟判断情况,如果强制情况下都不满足,那直接返回不满足if a[i] + b[i] < mid:return Falseif a[i] < mid:needchange += (mid - a[i] )if needchange > m :return Falsereturn Truel,r = 0,max(a)+max(b)
ans = 0
while l <= r:mid = (l+r) // 2if check(mid):ans = max(ans,mid)l = mid + 1else:r = mid - 1
print(ans)

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com