2019.01.17 bzoj1853: [Scoi2010]幸运数字(容斥+dfs)
传送门
搜索菜题,然而第一次没有注意然后爆longlonglong longlonglong了。
题意:称所有数位由6,86,86,8组成的数为幸运数字,问一个一个区间[l,r][l,r][l,r]中所有幸运数字及其倍数的个数。
思路:
先把所有的幸运数字找出来并筛去那些会算重的,剩下一共不超过100010001000个数。
即如果满足numi∣numjnum_i|num_jnumi∣numj就删去numjnum_jnumj。
然后考虑直接容斥+搜索算出答案。
现在就只用想怎么剪枝了。
- 当前的lcmlcmlcm大于b
- 把所有数从大到小排序。
- 由于每一次取lcmlcmlcm至少乘三,因此只要一个数是≤b/3\le b/3≤b/3的就不用加入最终的numnumnum集合。
然后直接搜就行了。
代码:
#include<bits/stdc++.h>
#define ri register int
using namespace std;
typedef long long ll;
const ll divv=1e9;
ll a,b,val[2500],lim,tot=0,ans=0,sig=0,coef[2500];
inline void calc(ll mul){
if(mul>b)return;
if(mul)val[++tot]=mul;
calc(mul*10+6),calc(mul*10+8);
}
inline ll gcd(ll a,ll b){while(b){ll t=a;a=b,b=t%a;}return a;}
inline ll lcm(ll a,ll b){return a/gcd(a,b)*b;}
inline bool check(ll x,ll y){
if((x/divv)*(y/divv))return 0;
return x*y<=b;
}
inline void dfs(int pos,int tim,ll mult){
if(mult>b)return;
if(pos==sig+1){
if(mult==1)return;
ans+=(b/mult-a/mult)*(tim&1?1:-1);
return;
}
dfs(pos+1,tim,mult);
ll x=mult/gcd(mult,coef[pos]),y=coef[pos];
if(check(x,y))dfs(pos+1,tim+1,x*y);
}
int main(){
cin>>a>>b,--a;
calc(0),ans=0;
sort(val+1,val+tot+1);
for(ri i=1;i<=tot;++i){
bool f=1;
for(ri j=1;j<i;++j)if(val[i]==val[i]/val[j]*val[j]){f=0;break;}
if(f){
if(val[i]<=b/3)coef[++sig]=val[i];
else ans+=b/val[i]-a/val[i];
}
}
reverse(coef+1,coef+sig+1);
dfs(1,0,1);
cout<<ans;
return 0;
}
2019.01.17 bzoj1853: [Scoi2010]幸运数字(容斥+dfs)的更多相关文章
- bzoj1853[Scoi2010]幸运数字 容斥
1853: [Scoi2010]幸运数字 Time Limit: 2 Sec Memory Limit: 64 MBSubmit: 3027 Solved: 1128[Submit][Status ...
- [BZOJ1853][Scoi2010]幸运数字 容斥+搜索剪枝
1853: [Scoi2010]幸运数字 Time Limit: 2 Sec Memory Limit: 64 MBSubmit: 3202 Solved: 1198[Submit][Status ...
- bzoj 1853: [Scoi2010]幸运数字 容斥
1853: [Scoi2010]幸运数字 Time Limit: 2 Sec Memory Limit: 64 MBSubmit: 1170 Solved: 406[Submit][Status] ...
- Luogu P2567 [SCOI2010]幸运数字 容斥+脑子
双倍经验:BZOJ 2393 Cirno的完美算数教室 做法:先把$[1,r]$中所有的幸运数字筛出来,然后用这些幸运数字来筛$[l,r]$中的近似幸运号码: 剪枝:当一个幸运数字$a[i]$是另一个 ...
- BZOJ1853 Scoi2010 幸运数字 【枚举+容斥】
BZOJ1853 Scoi2010 幸运数字 Description 在中国,很多人都把6和8视为是幸运数字!lxhgww也这样认为,于是他定义自己的“幸运号码”是十进制表示中只包含数字6和8的那些号 ...
- BZOJ1853 [Scoi2010]幸运数字 容斥原理
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1853 题意概括 求一个区间范围内,近似幸运数字的个数. 定义: 幸运数字:仅由6或者8组成的数字. ...
- BZOJ1853 [Scoi2010]幸运数字
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000作者博客:http://www.cnblogs.com/ljh2000-jump/转 ...
- bzoj1853: [Scoi2010]幸运数字 dp+容斥原理
在中国,很多人都把6和8视为是幸运数字!lxhgww也这样认为,于是他定义自己的“幸运号码”是十进制表示中只包含数字6和8的那些号码,比如68,666,888都是“幸运号码”!但是这种“幸运号码”总是 ...
- 并不对劲的bzoj1853:[SCOI2010]幸运数字
传送门-> 据说本题的正确读法是[shìng运数字]. 听上去本题很适合暴力,于是并不对劲的人就去写了.其实这题就是一个很普(有)通(趣)暴力+神奇的优化. 首先,会发现幸运数字很少,那么就先搜 ...
随机推荐
- React 入门实例教程【转】
Any day will do. 哪一天都行 Are you kidding? 你在开玩笑吧! Congratulations! 祝贺你! I don’t mean it. 我不是故意的. 原文作者: ...
- TZOJ 1210 The area(微积分)
描述 Ignatius bought a land last week, but he didn't know the area of the land because the land is enc ...
- python中类变量和成员变量、局部变量总结
class Member(): num= #类变量,可以直接用类调用,或用实例对象调用 def __init__(self,x,y): self.x=x #实例变量(成员变量),需要它是在类的构造函数 ...
- swift - xcode10 - 点击事件交互BUG - (手势和button的addTarget方法)
1. 现象button 点击闪退:没有任何原因 ,在听云检测上,显示 BUG2: 手势 没有任何作用,哪怕设置 isUserInteractionEnabled 和isEnabled 为true 都 ...
- golang语言中os包的学习与使用(文件,目录,进程的操作)
os中一些常用函数的使用: package main; import ( "os" "fmt" "time" "strings&q ...
- vue(ajax:axios中文文档)
axios 基于http客户端的promise,面向浏览器和nodejs 特色 浏览器端发起XMLHttpRequests请求 node端发起http请求 支持Promise API 监听请求和返回 ...
- winform closing事件注册
参考链接:http://blog.chinaunix.net/uid-215617-id-2213081.html
- 在Qt(C++)中与Python混合编程
一.PythonQt库 在Qt(C++)中与Python混合编程,可以使用PythonQt库. 网站首页:http://pythonqt.sourceforge.net 下载页面:https://so ...
- 从django的序列化到rest-framework 序列化
1.利用Django的view实现返回json数据 from django.views.generic import View from goods.models import Goods class ...
- eclipse Tomcat和 MYSQL JAVA web新手开发示例--登录界面连接数据库
登录界面login.jsp 1 <%@ page language="java" import="java.util.*" contentType=&qu ...