【Luogu】P2567幸运数字(容斥爆搜)
先预处理出幸运数,把成倍数关系的剔掉,然后用容斥原理搜索一下。
这里的容斥很像小学学的那个“班上有n个同学,有a个同学喜欢数学,b个同学喜欢语文……”那样。
#include<cstdio>
#include<cstdlib>
#include<cctype>
#include<algorithm>
#include<cstring>
#define maxn 200020
using namespace std;
inline long long read(){
long long num=,f=;
char ch=getchar();
while(!isdigit(ch)){
if(ch=='-') f=-;
ch=getchar();
}
while(isdigit(ch)){
num=num*+ch-'';
ch=getchar();
}
return num*f;
} long long q[maxn];int tot;
long long d[maxn];int cnt;
bool vis[maxn]; void find(int deep,long long now){
if(deep==){
q[++tot]=now;
return;
}
find(deep-,now*+);
find(deep-,now*+);
} bool cmp(long long a,long long b){ return a>b; } long long calc(long long l,long long r,long long e){
if(l%e==) l/=e;
else l=l/e+;
r/=e;
return r-l+;
} long long gcd(long long a,long long b){
return b==?a:gcd(b,a%b);
} long long ans=;
long long a,b; void dfs(int deep,int Cnt,long long val){
if(val>b) return;
if(deep>cnt){
if(Cnt==) return;
ans+=calc(a,b,val)*(Cnt&?:-);
return;
}
dfs(deep+,Cnt,val);
long long tmp=val/gcd(val,d[deep]);
if(1.0*tmp*d[deep]<=b) dfs(deep+,Cnt+,tmp*d[deep]);
} int main(){
a=read(),b=read();
for(int i=;i<=;++i) find(i,);
for(int i=;i<=tot;++i){
if(vis[i]==) d[++cnt]=q[i];
for(int j=i+;j<=tot;++j)
if(q[j]%q[i]==) vis[j]=;
}
sort(d+,d+cnt+,cmp);
dfs(,,);
printf("%lld\n",ans);
return ;
}
【Luogu】P2567幸运数字(容斥爆搜)的更多相关文章
- [SCOI2010]幸运数字(容斥+爆搜)
		在中国,很多人都把6和8视为是幸运数字!lxhgww也这样认为,于是他定义自己的“幸运号码”是十进制表示中只包含数字6和8的那些号码,比如68,666,888都是“幸运号码”!但是这种“幸运号码”总是 ... 
- Luogu P2567 [SCOI2010]幸运数字 容斥+脑子
		双倍经验:BZOJ 2393 Cirno的完美算数教室 做法:先把$[1,r]$中所有的幸运数字筛出来,然后用这些幸运数字来筛$[l,r]$中的近似幸运号码: 剪枝:当一个幸运数字$a[i]$是另一个 ... 
- [BZOJ1853][Scoi2010]幸运数字  容斥+搜索剪枝
		1853: [Scoi2010]幸运数字 Time Limit: 2 Sec Memory Limit: 64 MBSubmit: 3202 Solved: 1198[Submit][Status ... 
- bzoj1853[Scoi2010]幸运数字 容斥
		1853: [Scoi2010]幸运数字 Time Limit: 2 Sec Memory Limit: 64 MBSubmit: 3027 Solved: 1128[Submit][Status ... 
- bzoj 1853: [Scoi2010]幸运数字 容斥
		1853: [Scoi2010]幸运数字 Time Limit: 2 Sec Memory Limit: 64 MBSubmit: 1170 Solved: 406[Submit][Status] ... 
- 【BZOJ-1853&2393】幸运数字&Cirno的完美算数教室       容斥原理 + 爆搜 + 剪枝
		1853: [Scoi2010]幸运数字 Time Limit: 2 Sec Memory Limit: 64 MBSubmit: 1817 Solved: 665[Submit][Status] ... 
- P2567 [SCOI2010]幸运数字  DFS+容斥定理
		P2567 [SCOI2010]幸运数字 题目描述 在中国,很多人都把6和8视为是幸运数字!lxhgww也这样认为,于是他定义自己的“幸运号码”是十进制表示中只包含数字6和8的那些号码,比如68,66 ... 
- 2019.01.17 bzoj1853: [Scoi2010]幸运数字(容斥+dfs)
		传送门 搜索菜题,然而第一次没有注意然后爆longlonglong longlonglong了. 题意:称所有数位由6,86,86,8组成的数为幸运数字,问一个一个区间[l,r][l,r][l,r]中 ... 
- 【BZOJ1853】幸运数字(搜索,容斥)
		[BZOJ1853]幸运数字(搜索,容斥) 题面 BZOJ 洛谷 题解 成功轰下洛谷rk1,甚至超越了一个打表选手 这题思路很明显吧,先搞出来所有范围内的合法数字,然后直接容斥, 容斥的话显然没有别的 ... 
随机推荐
- 发现知乎的一个Bug,并且我绕过了此Bug,沾沾自喜中...
			发现问题 在知乎点击修改头像,上传图片时发现一片空白.凭着程序员的直觉,第一反应时看下控制台是否有报错.果然发现如下: Refused to load the image 'data:image/jp ... 
- Android(java)学习笔记118:BroadcastReceiver之 外拨电话的广播接收者
			1. 外拨电话的广播接收者: 首先我们示例工程一览表如下: (2)首先我们还是买一个收音机,定义一个OutCallReceiver继承自BroadcastReceiver,onReceive()方法中 ... 
- HTML之基本语法(表单)
			一.表单的基本介绍 表单:就是互联网上用于收集用户信息的一种结构,在HTML当中事先定义好了一种标签来完成此事,标签名称为form,它是一个双标签<form action="" ... 
- 1968: C/C++经典程序训练6---歌德巴赫猜想的证明
			1968: C/C++经典程序训练6---歌德巴赫猜想的证明 Time Limit: 1 Sec Memory Limit: 64 MBSubmit: 1165 Solved: 499[Submi ... 
- 谈谈TCP的四次挥手
			“挥手”是为了终止连接,TCP四次挥手的流程图如下: (在socket编程中,可以由客户端或服务端进行close操作来进行) 下面的图是由客户端主动关闭连接 MSL是什么?最长报文段寿命 ------ ... 
- Java基础面试操作题:Java代理工厂设计模式 ProxyFactory 有一个Baby类,有Cry行为,Baby可以配一个保姆 但是作为保姆必须遵守保姆协议:能够处理Baby类Cry的行为,如喂奶、哄睡觉。
			package com.swift; public class Baby_Baomu_ProxyFactory_Test { public static void main(String[] args ... 
- 洛谷 P2568 GCD
			https://www.luogu.org/problemnew/show/P2568#sub 最喜欢题面简洁的题目了. 本题为求两个数的gcd是素数,那么我们将x和y拆一下, 假设p为$gcd(x, ... 
- NOIP模拟赛 麻将
			[题目描述] 众所周知,麻将是我们国家的国粹.这段时间,小D也迷上了麻将这个老少皆宜的游戏. 小D觉得这些不同规则的麻将太麻烦了,所以他集合了很多种麻将规则创造出了一套D麻将.下面是D麻将的几个特点: ... 
- linux关于软件安装和测试
			软件都是盘上的安装之前确保已挂载完毕 1.安装软件 rpm -ivh httpd-2* 2.修改配置文件 vi /etc/httpd/conf/httpd.conf listen 8888 3 ... 
- Vue之数据传递
			基础:vue的响应式规则 简单的props更新 父组件 <template> <div> <block-a :out-data="x">< ... 
