Divide Interval 题解
背景
太逊了,调了三次才调出来,所以写篇题解寄念。LC好睿智
题意
给你两个数 \(a,b\),现在要从 \(a\) 跑到 \(b\),每次可以将当前的 \(a\) 拆分成 \(2^n\times m(n,m\in N)\) 的形式,并将它变成 \(2^n\times (m+1)\)。问最少变几次能跑到 \(b\),输出次数和每次变化前后 \(a\) 的值。
分析
这道题有一个一眼贪心。在一次变化后不会超过 \(b\) 的情况下,我们要让 \(n\) 的值尽可能大来使得 \(a\) 变化后更大。所以我们可以写一个函数来先找到 \(n\) 最大可以是多少,具体就是看看 \(a\) 的因数中最大的 \(2\) 的整次幂是多少,下面给出:
int p(int x)
{
int ans=1;
while(x%ans==0)
{
ans=ans<<1;
}
if(x%ans)ans/=2;
return ans;
}
然后计算出 \(m\),并判断这样拆分后一次变化是否会超过 \(b\),如果超过就让 \(n>>1\),直到满足条件。因为要先输出变化次数,所以用两个数组记录每次变化前后 \(a\) 的值即可。
细节
如果 \(a\) 的初值为 \(0\),我们发现此时 \(n\) 可以是任意值,所以我们特判一下,直接找到不大于 \(b\) 的最大的 \(2\) 的整次幂,让 \(a\) 变成它就行了。
Code
#include<bits/stdc++.h>
#define int long long
using namespace std;
inline int read()
{
int w=1,s=0;char ch=getchar();
while(!isdigit(ch)){if(ch=='-') w=-1;ch=getchar();}
while(isdigit(ch)){s=s*10+(ch-'0');ch=getchar();}
return w*s;
}
const int maxn=6e7+10;
int l,r;
int p(int x)//得出最大因数
{
int ans=1;
while(x%ans==0)
{
ans=ans<<1;
}
if(x%ans)ans/=2;
return ans;
}
int lo(int x)//得出最大2的整次幂
{
int i;
for(i=1;i<=x;i*=2);
if(i>x)i/=2;
return i;
}
int ansl[maxn],ansr[maxn],tot;//记录答案
signed main()
{
// freopen("test.in","r",stdin);
// freopen("test.out","w",stdout);
cin>>l>>r;
while(l<r)
{
if(l==r)break;
ansl[++tot]=l;
if(l==0)//特判
{
int pr=lo(r);
l=pr;
ansr[tot]=l;
continue;
}
int p2=p(l);
int bei=l/p2;//计算n和m
while(p2*(bei+1)>r)//向下缩小n
{
p2=p2>>1;
bei=l/p2;
}
l=p2*(bei+1);
ansr[tot]=l;
}
cout<<tot<<endl;
for(int i=1;i<=tot;i++)
cout<<ansl[i]<<' '<<ansr[i]<<endl;
return 0;
}
Divide Interval 题解的更多相关文章
- 算法与数据结构基础 - 排序(Sort)
排序基础 排序方法分两大类,一类是比较排序,快速排序(Quick Sort).归并排序(Merge Sort).插入排序(Insertion Sort).选择排序(Selection Sort).希尔 ...
- 【题解】The Great Divide [Uva10256]
[题解]The Great Divide [Uva10256] 传送门:\(\text{The Great Divide [Uva10256]}\) [题目描述] 输入多组数据,每组数据给定 \(n\ ...
- [LeetCode]题解(python):057-Insert Interval
题目来源 https://leetcode.com/problems/insert-interval/ Given a set of non-overlapping intervals, insert ...
- 【题解】【区间】【二分查找】【Leetcode】Insert Interval & Merge Intervals
Given a set of non-overlapping intervals, insert a new interval into the intervals (merge if necessa ...
- Codeforces 311D Interval Cubing 数学 + 线段树 (看题解)
Interval Cubing 这种数学题谁顶得住啊. 因为 (3 ^ 48) % (mod - 1)为 1 , 所以48个一个循环节, 用线段树直接维护. #include<bits/stdc ...
- 题解-CF1401E Divide Square
题面 CF1401E Divide Square 给一个正方形平面边长为 \(10^6\),给 \(n\) 条横线段和 \(m\) 条竖线段,每条线段都与正方形边缘相交且一条直线上不会有两条线段,求被 ...
- UVA10375 选择与除法 Choose and divide 题解
题目链接: https://www.luogu.org/problemnew/show/UVA10375 分析: 这道题可以用唯一分解定理来做. 什么是唯一分解定理?百度即可,这里也简介一下. 对于任 ...
- CH 4302 Interval GCD 题解
题意 给定一个长度为N的数列A,以及M条指令 (N≤5* 10^5, M<=10^5),每条指令可能是以下两种之一: "C l r d",表示把 A[l],A[l+1],-, ...
- 【CF1445D】Divide and Sum 题解
题目链接 题意简介 将一个长度为 2n 的数列平均分为两个子数列 p 和 q 后,p 按从小到大排序,q 按从大到小排序. 排序后,记 p 为 \(\{x_i\}\) ,q 为 \(\{y_i\}\) ...
- LeetCode OJ 题解
博客搬至blog.csgrandeur.com,cnblogs不再更新. 新的题解会更新在新博客:http://blog.csgrandeur.com/2014/01/15/LeetCode-OJ-S ...
随机推荐
- C#调用微软api文本转语音
目录 1.注册微软云服务,搭建文本转语音标准应用(每月500万字免费好像) 2.Visual studio使用nuget给程序安装Microsoft.CognitiveServices.Speech框 ...
- linux获取docker容器中的文件路径怎么表示
在Linux系统中,Docker容器中的文件路径与宿主机上的文件系统是隔离的,因此我们不能直接使用宿主机的文件系统路径来访问容器内的文件.但是,有几种方法可以让我们获取或操作Docker容器中的文件. ...
- Jenkins获取gitlab源代码
Jenkins获取gitlab源代码 Jenkins权限获取 在日常工作做由于Jenkins启动用户是Jenkins,在执行脚本时系统命令是无法让Jenkins执行的,如果需要Jenkins权限有两种 ...
- 【论文笔记】轻量级网络MobileNet
[深度学习]总目录 MobileNet V1:<MobileNets: Efficient Convolutional Neural Networks for MobileVision Appl ...
- Java中GUI
目录 1.Java GUI 概述 2.容器 2.1 窗口 2.2 弹窗和对话框 对话框 自定义弹窗 2.3 面板 普通面板 滚动面板 分隔面板 选项卡面板 3.布局 3.1.流式布局 3.2.网格布局 ...
- 关于 CSDN 的恶臭嘴脸
我有段时间确实希望通过 CSDN 增加我文章的阅读量.但是我怎么使用 CSDN,我想要的大概也就 cnblogs 相对符合预期,CSDN 真是垃圾. 为了钱真是什么都不要了,让我们这种没有自主经济来源 ...
- JS 中 == 和 === 区别是什么?
a.对于string,number等基础类型,==和===有区别:不同类型间比较,==之比较"转化成同一类型后的值"看"值"是否相等,===如 果类型不 ...
- OAuth + Security - 错误收集
Could not decode JSON for additional information: BaseClientDetails 完整的错误输出如下: 2019-12-03 22:18:37.2 ...
- HTML/CSS复习
CSS复习 HTML语义化 有利于SEO(搜索引擎优化) 便于阅读,修改 对盲人等不方便浏览网页的人来说比较方便 盒模型 盒模型有border-box和content-box两种,默认是content ...
- 使用vscode写Markdown并且导出为pdf(干货)
目录 序言 下载vscode 安装插件 markdown语法 导出为pdf 序言 大家在学习过程中都会有记笔记的好习惯(美观的笔记当然是上上选),于是,Markdown就是一个不错的选择,待会也会附上 ...