题目:http://www.lydsy.com/JudgeOnline/problem.php?id=1853

容斥原理的应用。

发现十位的话只有2047个只含6或8的数,故可以存。它们的倍数个数只要到时候用边界除以一下就行了。

但容斥原理是指数级别的。故剪枝:

  因为比 r 大的 lcm 就没用了。故若当前的累计lcm已经大于r,因为越乘越大,故直接剪掉。

  怎样考虑顺序才能使剪枝更有效呢?

  在每一层都有两种情况:选当前元素和不选当前元素。一直递归到序号大于n时更新答案并return;

  也就是排在前面的元素改一下,就把它后面的元素的种种状况都考虑完,之后再改一下这个前面的元素,再……

  若从小到大排序,则经过种种状态到达很后面一个位置时突然发现超过了r,于是回溯;这样会把“前面的种种状态”都遍历一遍,每次到了这儿回溯;

  但若从大到小排序,则原来的“前面的种种状态”变成了“后面的种种状态”,一旦在此return,就不会遍历后面了,剪枝变得更有效了。

  也就是值越大,越容易使累计的lcm越过r,所以把值大的放在前面,就可以使剪枝更有效。

  似乎因为很容易就越过r了,所以加了剪枝就可以轻松过了。

小注意:lcm算出来的话似乎会爆long long,但可以用long long记在参数里。所以是先求一个tmp,再用double比较。(虽然double精度有点低)。

    但有一个很好的方法!就是不比较 a[k] * tmp <=r,而是比较 tmp <= r / a[k] !这样就肯定不会爆了~

但:本代码中所有都是 l l。另有把计数的k,cnt之类写成int的(只有这一点区别),就RE了。真是不明所以。

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
typedef long long ll;
ll l,r,a[],b[],m,n,ans;
bool er[];
void pre(ll k)
{
if(k>r)return;
a[++m]=k;
pre(k*+);
pre(k*+);
}
ll gcd(ll u,ll v)
{
return v==?u:gcd(v,u%v);
}
void dfs(ll k,ll cnt,ll z)//第k号 选了cnt个元素 之前的lcm为z
{
if(k>n)
{
if(!cnt)return; //////
if(cnt&)ans+=r/z-(l-)/z;
else ans-=r/z-(l-)/z;
return;
}
dfs(k+,cnt,z);
ll tmp=z/gcd(a[k],z);
if((double)a[k]*tmp<=r)dfs(k+,cnt+,a[k]*tmp);
}
int main()
{
scanf("%lld%lld",&l,&r);
pre();pre();
sort(a+,a+m+);
for(ll i=;i<=m;i++)
if(!er[i])
{
for(ll j=i+;j<=m;j++)
if(a[j]%a[i]==)er[j]=;
b[++n]=a[i];
}
for(ll i=;i<=n;i++)
a[i]=b[n-i+];
dfs(,,); ///z=1
printf("%lld",ans);
return ;
}

bzoj1853幸运数字的更多相关文章

  1. [bzoj1853]幸运数字

    容易发现幸运数字只有1024个,暴力标记倍数还是会tle的 容斥,即从中任选i个的lcm,复杂度为$o(2^1024)$ 剪枝一:当答案超过1024就不用算了 剪枝二:当某个数是另一个数的倍数时就删掉 ...

  2. bzoj1853幸运数字——容斥原理

    题目:http://www.lydsy.com/JudgeOnline/problem.php?id=1853 dfs实现容斥原理即可. 注意:若在init中写“cnt++”,则出来后需要先cnt-- ...

  3. 【BZOJ-1853&2393】幸运数字&Cirno的完美算数教室 容斥原理 + 爆搜 + 剪枝

    1853: [Scoi2010]幸运数字 Time Limit: 2 Sec  Memory Limit: 64 MBSubmit: 1817  Solved: 665[Submit][Status] ...

  4. 【bzoj1853】 Scoi2010—幸运数字

    http://www.lydsy.com/JudgeOnline/problem.php?id=1853 (题目链接) 今天考试考了容斥,结果空知道结论却不会写→_→ 题意 求区间中不含6,8两个数字 ...

  5. BZOJ1853 [Scoi2010]幸运数字 容斥原理

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1853 题意概括 求一个区间范围内,近似幸运数字的个数. 定义: 幸运数字:仅由6或者8组成的数字. ...

  6. 【BZOJ1853】幸运数字(搜索,容斥)

    [BZOJ1853]幸运数字(搜索,容斥) 题面 BZOJ 洛谷 题解 成功轰下洛谷rk1,甚至超越了一个打表选手 这题思路很明显吧,先搞出来所有范围内的合法数字,然后直接容斥, 容斥的话显然没有别的 ...

  7. BZOJ1853 Scoi2010 幸运数字 【枚举+容斥】

    BZOJ1853 Scoi2010 幸运数字 Description 在中国,很多人都把6和8视为是幸运数字!lxhgww也这样认为,于是他定义自己的“幸运号码”是十进制表示中只包含数字6和8的那些号 ...

  8. 【bzoj1853】: [Scoi2010]幸运数字 数论-容斥原理

    [bzoj1853]: [Scoi2010]幸运数字 预处理出所有幸运数字然后容斥原理 但是幸运数字是2logn个数的 直接搞会炸 所以把成倍数的处理掉 然后发现还是会T 所以数字要从大到小处理会快很 ...

  9. 【BZOJ1853/2393】[Scoi2010]幸运数字/Cirno的完美算数教室 DFS+容斥

    [BZOJ1853][Scoi2010]幸运数字 Description 在中国,很多人都把6和8视为是幸运数字!lxhgww也这样认为,于是他定义自己的“幸运号码”是十进制表示中只包含数字6和8的那 ...

随机推荐

  1. vuex2.0+两个小例子

    首先vuex概念比较多,一定要搞懂里面的概念,可以参考官网Vuex2.0概念,我写此文的目的是希望能对前端爱好者提供个参考,加深对vuex2.0各核心概念的理解. 废话少说,直接上干货.这是官网上的一 ...

  2. SDL检查

    在用 Visual Studio 编译比较早的代码时,经常会遇到错误: 错误 C4996 'wcscpy': This function or variable may be unsafe. Cons ...

  3. VGA

    VGA(Video Graphics Array )视频图形阵列,是IBM在1987年随PS/2机一起推出的一种视频传输标准,具有分辨率高.显示速率快.颜色丰富等优点,在彩色显示器领域得到了广泛的应用 ...

  4. learning docker steps(4) ----- docker swarm 初次体验

    参考:https://docs.docker.com/get-started/part4/ 了解 swarm 集群 swarm 是一组运行 Docker 并且已加入集群中的机器.执行此操作后,您可以继 ...

  5. Python Django 之 Views HttpRequest HttpReponse

    一.Python Django 之 Views 数据交互 http请求中产生两个人核心对象: http请求:HttpRequest对象 http响应:HttpReponse对象 所在位置django. ...

  6. pyqt(一)安装及配置。

    一:简介 PyQt实现了一个Python模块集.它有超过300类,将近6000个函数和方法.它是一个多平台的工具包,可以运行在所有主要操作系统上,包括UNIX,Windows和Mac. PyQt采用双 ...

  7. iPad mini Retina越狱小结【2014年02月06日 - 初稿】

    Update History 2014年02月06日 - 初稿 0.引言 本来一直都没有苹果的产品除了第一代的iPod(没怎么使用最后大学送人了 @李清纯(255270520) ,巧合的是老妈学校发了 ...

  8. 2019.1.5 China’s population

    China’s population is expected to hit a peak of 1.44 billion in 2029, and start to experience negati ...

  9. mysql数据库索引相关

    一 介绍 什么是索引? 索引在MySQL中也叫做“键”,是存储引擎用于快速找到记录的一种数据结构.索引对于良好的性能非常关键,尤其是当表中的数据量越来越大时,索引对于性能的影响愈发重要.索引优化应该是 ...

  10. REST easy with kbmMW #14 – DB Controlled login

    介绍 关于如何使用授权和登录管理来构建应用服务器还存在一些问题,其中之一就是用户及其角色如何在在数据库中定义.该文将解释使用TkbmMWAuthorizationManager解决此问题的一种方法.有 ...