数论分块
数论分块的结论
给定一个n,n / i的取值有级别个,并且对于每一个i,它对应的分块的区间为(i, n / (n / i)).
A - 区间最大值
题目链接
https://ac.nowcoder.com/acm/contest/30896/A
解析
n % i = n - (n / i) * i,所以原题等价于求(n / i) * i的最小值,从矩阵分块的角度思考,应该选择每个分块最左端的那个点,又由于矩阵分块为的做法,所以对于每一个询问,利用矩阵分块扫一遍即可。
Ac代码
点击查看代码
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
typedef long long ll;
ll n, m;
int main()
{
scanf("%lld%lld", &n, &m);
while(m --){
ll ans = 0;
ll l, r, rr;
scanf("%lld%lld", &l, &r);
for(ll i = l; i <= r; i = rr + 1){
ans = max(ans, n - (n / i) * i);
rr = n / (n / i);
}
printf("%lld\n", ans);
}
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架