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

汕头正规网站建设模板总部高级搜索引擎

汕头正规网站建设模板总部,高级搜索引擎,福州市网站建设,wordpress克隆文章目录 习题肖恩的n次根分巧克力2.卡牌 二分是十分重要的一个算法,常常用于求解一定范围内,找到满足条件的边界值的情况主要分为浮点数二分和整数二分二分问题,最主要是写出这个check函数,这个check函数最主要就是使用模拟的方法…

文章目录

  • 习题
    • 肖恩的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)
http://www.dtcms.com/wzjs/77588.html

相关文章:

  • win10 电脑做网站服务器生成关键词的软件
  • 电子商务网站建设重要性seo是什么软件
  • 微网站开发 mui框架长沙网络推广小公司
  • 狮山公司网站建设软文写手兼职
  • 群站优化之链轮模式可以访问违规网站的浏览器
  • 网站建好用电脑做服务器合肥网络营销公司
  • 用html制作网站流程网站seo外包价格
  • 网站建设太金手指六六十八竞价sem托管公司
  • 爱射影院网站建设中营销推广seo
  • 做网站备完备案需要干什么北京百度网讯人工客服电话
  • 商城网站建设的优势上饶seo博客
  • seo的中文含义是什么关键词优化课程
  • 建设一个人才网站需要的人才营销推广方案范文
  • 吕梁市建设局网站苏州网站排名推广
  • 做网站要交百分七十定金公司网站搭建
  • 个人网站制作在线seo交流中心
  • 天津网站建设外包如何提高自己的营销能力
  • 三水网站设计seo标题优化
  • 金华市有网站建设最低价东莞网站自动化推广
  • 怎么查到网站是谁做的免费推广网站注册入口
  • 深色系网站百度推广优化工具
  • 义乌市建设局官方网站全网整合营销推广方案
  • wordpress 自定义后台引擎优化是什么工作
  • 深圳设计公司有哪家成都网站优化平台
  • 如何学习wordpress广西seo快速排名
  • 网站上面的头像怎么做的郑州互联网公司排名
  • 成都微信网站建设公司哪家好百度推广首次开户需要多少钱
  • 昆明网站建设价格今天的新闻大事10条
  • 赣州做网站哪家好百度商务合作电话
  • 西安网络建站公司各大网站排名