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

D1.Chopping Carrots (Easy Version)【数学,二分,暴力,思维】

链接
理论基础
已知正整数a,v,求证m=⌊av⌋是满足⌊am⌋⩾v的最大的m,其中x是正整数已知正整数a,v,求证m=\lfloor \frac {a}{v} \rfloor是满足\lfloor \frac {a}{m} \rfloor \geqslant v的最大的m,其中x是正整数已知正整数a,v,求证m=va是满足mav的最大的m,其中x是正整数
先证不等号成立根据整除的定义可以得到先证不等号成立根据整除的定义可以得到先证不等号成立根据整除的定义可以得到
a=vm+r(0⩽r<v)a=vm+r(0\leqslant r<v)a=vm+r(0r<v)
⌊av⌋=m\lfloor \frac {a}{v} \rfloor=mva=m
⌊am⌋=⌊vm+rm⌋=v+⌊rm⌋⩾v\lfloor \frac {a}{m} \rfloor=\lfloor \frac {vm+r}{m} \rfloor=v+\lfloor \frac {r}{m} \rfloor \geqslant vma=mvm+r=v+mrv
再证这个m是满足不等式的最大的m,是m的极限值,用反证法再证这个m是满足不等式的最大的m,是m的极限值,用反证法再证这个m是满足不等式的最大的m,是m的极限值,用反证法
如果存在这样的数使得不等式成立,只需证m+1使得这样的不等式成立如果存在这样的数使得不等式成立,只需证m+1使得这样的不等式成立如果存在这样的数使得不等式成立,只需证m+1使得这样的不等式成立
⌊am+1⌋=⌊vm+rm+1⌋=⌊v(m+1)+r−vm+1⌋=v+⌊r−vm+1⌋\lfloor \frac {a}{m+1} \rfloor=\lfloor \frac {vm+r}{m+1} \rfloor=\lfloor \frac {v(m+1)+r-v}{m+1} \rfloor=v+\lfloor \frac {r-v}{m+1} \rfloorm+1a=m+1vm+r=m+1v(m+1)+rv=v+m+1rv
其中r−v是负数,根据高斯函数的定义,⌊r−vm+1⌋⩽−1其中r-v是负数,根据高斯函数的定义,\lfloor \frac {r-v}{m+1} \rfloor \leqslant-1其中rv是负数,根据高斯函数的定义,m+1rv1
∴⌊am+1⌋<v\therefore \lfloor \frac {a}{m+1} \rfloor <vm+1a<v
故不存在更大的m了故不存在更大的m了故不存在更大的m
分析
这道题,由于数值比较小,我们考虑枚举下限0~a[0],虽然有些数值不一定取到但是没有关系,因为,如果真的没有任何一个数能够取到的话,只要改变数值的大小就可以使得某一个数取到,这样差值就会变小,刚刚的非法的答案就不会有影响。对于某个下限,我们枚举最大的p使得不等式成立,也就是让整除结果尽可能接近v使得差值最小。因为差值最小是零,所有我们可以枚举所有的下限,尽管可能有些数是取不到的但是这些下限必然是不少最终的 答案,所有没有关系。
实现

#include <bits/stdc++.h>
#define ll long long
#define ls (p << 1)
#define rs (p << 1 | 1)
#define inf 0x3f3f3f3f
#define INF 0x3f3f3f3f3f3f3f3f
using namespace std;
typedef pair<int, int> PII;
const int N = 3005;
int a[N];
void solve() {int n, k;cin >> n >> k;for (int i = 1; i <= n; i++) cin >> a[i];int ans = inf;for (int i = 0; i <= a[1]; i++) {int maxn = 0;for (int j = 1; j <= n; j++) {int x = min(k, (i ? (a[j] / i) : k));//居然不考虑零也是可以的,我也是很迷惑的,如果真的想不到这个东西其实也是可以用二分的maxn = max(maxn, a[j] / x);}ans = min(ans, maxn - i);}cout << ans << '\n';
}
int main(){ios::sync_with_stdio(false);cin.tie(0);int T = 1;cin >> T;while (T--) solve();return 0;
}
http://www.lryc.cn/news/17943.html

相关文章:

  • 【Maven】(二)使用 Maven 创建并运行项目、聊聊 POM 中的坐标与版本号的规则
  • (考研湖科大教书匠计算机网络)第六章应用层-第六节:电子邮件
  • 一、初识TypeScript、什么是类型系统
  • 一文了解什么是字节对齐(超详细)
  • Java无法通过形参设置为null改变实参
  • GEE:样本点选择教程
  • 3.知识图谱相关学习资料汇总,提供系统化的知识图谱学习路径。一份详细的指南,补全你知识的漏洞
  • TypeScript学习笔记(一)编译环境、数据类型、函数类型、联合类型
  • 为什么要移除数据库物理外键?
  • Linux 计划任务讲解
  • Qt智能指针模板类的使用方式和区别总结
  • 【STL】模拟实现vector
  • Window 的 PHP XAMPP 安装 mongodb 的扩展
  • Codeforces Round #849 (Div. 4)(E~G)
  • 网易云音乐财报解读:收入大增亏损收窄,“云村”草长莺飞
  • MariaDB-10.8.6安装+主从搭建
  • Win11系统user profile service服务登录失败解决方法
  • Solon2 之基础:四、应用启动过程与完整生命周期
  • Java性能分析
  • 2023年阿里云ECS服务器S6/C6/G6/N4/R6/sn2ne/sn1ne/se1ne处理器CPU性能详解
  • 数据分析与SAS学习笔记8
  • 切割多个conf文件Nginx和Apache配置多版本PHP
  • 使用Navicat进行SSH加密方式连接MySQL数据库
  • 大数据Hadoop教程-学习笔记04【数据仓库基础与Apache Hive入门】
  • 20230223 刚体上的两个点速度之间的关系
  • 17.1 Display system tasks
  • 【4】linux命令每日分享——cd切换路径
  • 诚邀您体验人工智能AI
  • 【蓝桥杯集训·每日一题】AcWing 2058. 笨拙的手指
  • 运维排查篇 | Linux 连接跟踪表满了怎么处理