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

武安城乡建设网站潍坊seo推广

武安城乡建设网站,潍坊seo推广,微信crm是什么,济南优化网站方法问题描述 小蓝有一个神奇的炉子用于将普通金属 O 冶炼成为一种特殊金属 X。这个炉子有一个称作转换率的属性 V,V 是一个正整数,这意味着消耗 V 个普通金属 O 恰好可以冶炼出一个特殊金属 X,当普通金属 O 的数目不足 V 时,无法继续…

问题描述

小蓝有一个神奇的炉子用于将普通金属 O 冶炼成为一种特殊金属 X。这个炉子有一个称作转换率的属性 V,V 是一个正整数,这意味着消耗 V 个普通金属 O 恰好可以冶炼出一个特殊金属 X,当普通金属 O 的数目不足 V 时,无法继续冶炼。

现在给出了 N 条冶炼记录,每条记录中包含两个整数 A 和 B,这表示本次投入了 A 个普通金属 O,最终冶炼出了 B 个特殊金属 X。每条记录都是独立的,这意味着上一次没消耗完的普通金属 O 不会累加到下一次的冶炼当中。

根据这 N 条冶炼记录,请你推测出转换率 V 的最小值和最大值分别可能是多少,题目保证评测数据不存在无解的情况。

输入格式

第一行一个整数 N,表示冶炼记录的数目。

接下来输入 N 行,每行两个整数 A、B,含义如题目所述。

输出格式

输出两个整数,分别表示 V 可能的最小值和最大值,中间用空格分开。

输入样例

3

75 3

53 2

59 2

输出样例

20 25

#include<bits/stdc++.h>  
#define ll long long // 定义长整型别名  
using namespace std;  
const ll N = 1e4 + 10; // 定义常数N表示数组大小  
int a[N], b[N]; // 定义两个数组a和b  
int n; // 定义变量n表示数组元素数量  // 检查是否存在一个值x,使得对于所有i,b[i] < a[i] / x不成立(即找最小值时的检查函数)  
bool check_min(int mid){  for(int i = 0; i < n; i++){  if(b[i] < a[i] / mid){ // 注意这里使用的是整数除法  return false; // 如果存在不满足条件的i,则返回false  }  }  return true; // 如果所有i都满足条件,则返回true  
}  // 检查是否存在一个值x,使得对于所有i,b[i] > a[i] / x不成立(即找最大值时的检查函数)  
bool check_max(int mid){  for(int i = 0; i < n; i++){  if(b[i] > a[i] / mid){ // 注意这里同样使用的是整数除法  return false; // 如果存在不满足条件的i,则返回false  }  }  return true; // 如果所有i都满足条件,则返回true  
}  void solve(){  cin >> n; // 输入数组元素数量n  for(int i = 0; i < n; i++){  cin >> a[i] >> b[i]; // 输入数组a和b的元素  }  int lmin = 1, rmin = 1e9; // 定义二分查找的左右边界,用于找最小值  while(lmin < rmin){ // 二分查找找最小值  int mid = lmin + rmin >> 1; // 计算中点  if(check_min(mid)){ // 如果mid满足条件(即不存在b[i] < a[i] / mid的情况)  rmin = mid; // 更新右边界为mid,继续向左搜索  }else{  lmin = mid + 1; // 否则,更新左边界为mid+1  }  }  int lmax = 1, rmax = 1e9; // 定义二分查找的左右边界,用于找最大值  while(lmax < rmax){ // 二分查找找最大值  int mid = lmax + rmax + 1 >> 1; // 计算中点,注意要加1以避免死循环  if(check_max(mid)){ // 如果mid满足条件(即不存在b[i] > a[i] / mid的情况)  lmax = mid; // 更新左边界为mid,继续向右搜索  }else{  rmax = mid - 1; // 否则,更新右边界为mid-1  }  }  cout << lmin << " " << lmax << '\n'; // 输出找到的最小值和最大值  
}  signed main(){  ios::sync_with_stdio(0); // 取消C++和C的输入输出同步  cin.tie(0); // 解除cin与cout的绑定  cout.tie(0);  int t = 1; // 定义测试用例数量(这里固定为1)  while(t--){ // 循环处理每个测试用例  solve(); // 调用solve函数处理测试用例  }  return 0;  
}

二分模版整理

// 二分查找模板的注释  
// 向左找目标值(找满足条件的最小值)  
while(l < r){  int mid = l + r >> 1; // 计算中点  if(check(mid)){ // 如果mid满足条件  r = mid; // 更新右边界为mid,继续向左搜索  }else{  l = mid + 1; // 否则,更新左边界为mid+1  }  
}  // 向右找目标值(找满足条件的最大值)  
while(l < r){  int mid = l + r + 1 >> 1; // 为了避免死循环,当l和r相邻时mid应取r的下一位置  if(check(mid)){ // 如果mid满足条件  l = mid; // 更新左边界为mid,继续向右搜索  }else{  r = mid - 1; // 否则,更新右边界为mid-1  }  
}   

http://www.hkea.cn/news/474479/

相关文章:

  • 宁波有做网站的地方吗seo报价单
  • 深圳企业网站开发中国法律服务网app最新下载
  • 大连企业网站建站国外域名注册网站
  • 站长工具seo综合查询权重百度在线搜索
  • 伊犁网站建设评价怎样才能上百度
  • 房地产网站建设方案百度实名认证
  • 做外贸可以在哪些网站注册网络项目免费的资源网
  • 中国建设银行信用卡网站首页青岛关键词优化平台
  • 阿里云网站建设考试题目长沙网站推广服务公司
  • 甘肃建设项目审批权限网站俄罗斯搜索引擎yandex官网入口
  • 网站建设公司新员工培训ppt模板百度热门搜索排行榜
  • 仿魔客吧网站模板网址大全是ie浏览器吗
  • 网站产品后台界面怎么做湖南关键词排名推广
  • 网站数据每隔几秒切换怎么做的湖南百度seo排名点击软件
  • 网站制作先学什么百度新闻下载安装
  • 河南省网站建设哪家好免费观看行情软件网站进入
  • 粘合剂东莞网站建设体育热点新闻
  • 百度网站排名关键词整站优化培训网站建设
  • 网络平台代理seo外包 杭州
  • 东方头条网站源码免费推广软件工具
  • 北京网站建设公司分享网站改版注意事项流程优化四个方法
  • 案例学 网页设计与网站建设手机百度seo快速排名
  • 江门网站建设总部电话产品推广渠道有哪些
  • 网站建设全攻略站长之家ping检测
  • 导航网站 cmsgoogle chrome谷歌浏览器
  • wordpress看其他人博客优化师是做什么的
  • 现在哪个网站还做白拿2021小说排行榜百度风云榜
  • 网站流量seo提升seo排名的方法
  • 做html网站模板下载地址网站页面布局和样式设计
  • 公司网站邮箱费用磁力宅在线搜种子