HDU4349 Xiao Ming's Hope Lucas定理
来源:互联网 发布:互联网金融矩阵 编辑:程序博客网 时间:2024/06/10 03:32
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4349
题目大意:找出杨辉三角第n+1行中有多少个奇数。
分析:n的范围比较大(10^8数量级),考虑到大组合数取模(找奇数,即对2取模)的问题,自然而然就想到Lucas了(关于Lucas定理:点击打开链接)。我们知道对于求C(n,m)mod p,Lucas定理是把组合数中的n和m换成p进制的数,对于这道题,我们可以直接用n,m的二进制来做,要想得到奇数,无非只有C(1,0),C(1,1),C(0,0)这三种情况的值是1,C(0,1)是等于0的==>即,对于n二进制对应为0时候,m相对位必须为0,;对于n二进制对应为1的数,m有0和1两种选择,这样结果就很显然了,奇数个数即为2^cnt(cnt为n的二进制中1的个数)。
实现代码如下:
#include<iostream>#include<cstdio>using namespace std;int main(){ int n; while(scanf("%d",&n)!=-1) { int cnt=0; while(n) { if(n&1) cnt++; n>>=1; } printf("%d\n",1<<cnt); } return 0;}
0 0
- HDU4349 Xiao Ming's Hope Lucas定理
- HDU4349-Xiao Ming's Hope(Lucas定理)
- [HDU4349]Xiao Ming's Hope(组合数学Lucas定理)
- hdu 4349 Xiao Ming's Hope(Lucas定理)
- HDU 4349 Xiao Ming's Hope(数学题,Lucas定理)
- HDU 4349-Xiao Ming's Hope(Lucas定理的推广)
- hdu 4349 Xiao Ming's Hope,lucas定理
- HDU 4349 Xiao Ming's Hope (Lucas定理的应用)
- HDOJ 4349 Xiao Ming's Hope (Lucas定理变形)
- [HDU 4349] Xiao Ming's Hope (lucas定理)
- hdu 4349 Xiao Ming's Hope (Lucas定理)
- HDU 4349 Xiao Ming's Hope(思路 lucas定理)
- hdu 4349 Xiao Ming's Hope(Lucas定理)
- hdu4349 Xiao Ming's Hope-----多校联合五
- hdu - 4349 - Xiao Ming's Hope - 大大的Lucas定理 && 小小的乘法逆元
- HDU 4349 Xiao Ming's Hope (组合数的奇偶性&&Lucas定理)
- HDU 4349 Xiao Ming's Hope(Lucas定理的推导)
- HDU ACM 4349 Xiao Ming's Hope ->lucas定理的推到
- 01线程是一个程序里不同的执行路径
- JS 给某个对象添加专属方法
- TCP/IP-----区别、缓存、流量控制、拥塞控制
- unity3d 在shader中创建及使用Texture3D
- word公式居中标号右对齐编辑方法
- HDU4349 Xiao Ming's Hope Lucas定理
- 大话设计模式--笔记
- ASM(active shape model)算法简介(一)
- tintColor和barTintColor的使用
- ffmpeg对mpeg2-TS解析的最详细分析
- Mysql 自动备份与恢复
- 带技巧的暴力-ZOJ 3710 [Friends
- ubuntu下matplotlib中文字体的设置
- IOS-OC中获取某个数的绝对值