【题解】Luogu P4317 花神的数论题 组合数

前言

今天实在是太冷了!!!

o(*////▽////*)q

导致我这个菜鸡硬生生把一道数位dp写成了组合数水过(还不是因为数位dp题解没看懂



显然题意都告诉你了,$sum(i)$表示二进制位下的几个一,可以想到组合意义,在一个$i$位的二进制数中填$j$个1的方案数

预处理个50*50的杨辉三角,完全不需要求线性逆元

最后快速幂累乘出答案即可

code

 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 namespace gengyf{
 4 #define ll long long
 5 #define int long long
 6 const int maxn=1e4+10;
 7 const int mod=1e7+7;
 8 inline int read(){
 9     int f=1,x=0;char s=getchar();
10     while(s<‘0‘||s>‘9‘){if(s==‘-‘)f=-1;s=getchar();}
11     while(s>=‘0‘&&s<=‘9‘){x=x*10+s-‘0‘;s=getchar();}
12     return f*x;
13 }
14 int n,C[55][55],d[maxn],num[maxn],ans=1;
15 void pre(){
16     for(int i=0;i<=50;i++)C[i][0]=1;
17     for(int i=1;i<=50;i++)
18         for(int j=1;j<=50;j++){
19             C[i][j]=C[i-1][j]+C[i-1][j-1];
20         }
21 }
22 int qpow(int a,int b){
23     int tmp=1;
24     while(b){
25         if(b&1)tmp=tmp*a%mod;
26         a=a*a%mod;b>>=1;
27     }
28     return tmp;
29 }
30 int main(){
31     n=read();
32     pre();
33     int len=0,cnt=0;
34     while(n){
35         d[++len]=n&1;
36         n>>=1;
37     }
38     for(int i=len;i;--i){
39         if(d[i]){
40             for(int j=1;j<i;++j)
41                 num[cnt+j]+=C[i-1][j];
42                 ++num[++cnt];
43         }
44     }
45     for(int i=1;i<=len;++i){
46         ans=ans*qpow(i,num[i])%mod;
47     }
48     printf("%lld",ans);
49     return 0;
50 }
51 }
52 signed main(){
53   gengyf::main();
54   return 0;
55 }



后续

在写这篇$boke$的时候,一只大佬飘过,顺便说他用的数位dp,又被了

原文地址:https://www.cnblogs.com/gengyf/p/11648163.html

时间: 2024-11-17 18:10:12

【题解】Luogu P4317 花神的数论题 组合数的相关文章

【BZOJ3209】花神的数论题 数位DP

[BZOJ3209]花神的数论题 Description 背景众所周知,花神多年来凭借无边的神力狂虐各大 OJ.OI.CF.TC …… 当然也包括 CH 啦.描述话说花神这天又来讲课了.课后照例有超级难的神题啦…… 我等蒟蒻又遭殃了.花神的题目是这样的设 sum(i) 表示 i 的二进制表示中 1 的个数.给出一个正整数 N ,花神要问你派(Sum(i)),也就是 sum(1)—sum(N) 的乘积. Input 一个正整数 N. Output 一个数,答案模 10000007 的值. Samp

BZOJ3209: 花神的数论题

3209: 花神的数论题 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 689  Solved: 334[Submit][Status] Description 背景众所周知,花神多年来凭借无边的神力狂虐各大 OJ.OI.CF.TC …… 当然也包括 CH 啦.描述话说花神这天又来讲课了.课后照例有超级难的神题啦…… 我等蒟蒻又遭殃了.花神的题目是这样的设 sum(i) 表示 i 的二进制表示中 1 的个数.给出一个正整数 N ,花神要问你派(S

bzoj3209:3209: 花神的数论题

觉得还是数位dp的那种解题形式但是没有认真的想,一下子就看题解.其实还是设置状态转移.一定要多思考啊f[i][j]=f[i-1][j]+g[i-1][j] g[i][j]=f[i-1][j-1]+g[i-1][j]; 然后我就开始gang.然后先是for for j没有从0开始.然后是cnt增加的时候忘了*,接着是1<<tmp没有用ll,还有是读入优化没有用longlong,最后成功的过了若干较小的数据.WAWAWAWAWA5发.最后发现指数不能直接取模!.终于AC了喜极而泣TAT =>

HYSBZ 3209: 花神的数论题

题目连接:http://www.lydsy.com/JudgeOnline/problem.php?id=3209 花神的数论题 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1148  Solved: 535[Submit][Status][Discuss] Description 背景众所周知,花神多年来凭借无边的神力狂虐各大 OJ.OI.CF.TC …… 当然也包括 CH 啦.描述话说花神这天又来讲课了.课后照例有超级难的神题啦…… 我等蒟

HYSBZ 3209 花神的数论题(数位dp)

3209: 花神的数论题 Time Limit: 10 Sec  Memory Limit: 128 MB Submit: 1148  Solved: 535 [Submit][Status][Discuss] Description 背景 众所周知,花神多年来凭借无边的神力狂虐各大 OJ.OI.CF.TC -- 当然也包括 CH 啦. 描述 话说花神这天又来讲课了.课后照例有超级难的神题啦-- 我等蒟蒻又遭殃了. 花神的题目是这样的 设 sum(i) 表示 i 的二进制表示中 1 的个数.给出

BZOJ:3209: 花神的数论题

今天居然没参考任何资料解决了这道数位DP,事先只是搞一道数论题练练: 思路:求SUM[1]-SUM[N]的二进制的乘积mod1000000007: N<=10^15;BZOJ的题不会是几个简单的FOR就完结的, 假如N的二进制是:1001001: 位数:1234567 那么当第一位是0的情况:那么数就是000000-111111 序列号:  123456-123456 发现我们可以用排列组合算出二进制有1-6个1的数比如:1个1就是C[6][1],2个1就是C[6][2],...... 当第一位

bzoj 3209: 花神的数论题 数位dp

3209: 花神的数论题 Time Limit: 10 Sec  Memory Limit: 128 MB[Submit][Status][Discuss] Description 背景众所周知,花神多年来凭借无边的神力狂虐各大 OJ.OI.CF.TC …… 当然也包括 CH 啦.描述话说花神这天又来讲课了.课后照例有超级难的神题啦…… 我等蒟蒻又遭殃了.花神的题目是这样的设 sum(i) 表示 i 的二进制表示中 1 的个数.给出一个正整数 N ,花神要问你派(Sum(i)),也就是 sum(

花神的数论题(数位dp)

规定sum[i] 为i里面含1的个数 ,求从1-N sum[i]的乘积. 数为64位内的,也就是sum[i]<=64的,这样可以dp求出1-N中含k个1的数有多少个,快速幂一下就可以了. 有个地方没开LL ,WA了几次. 1 #include <iostream> 2 #include<cstdio> 3 #include<cstring> 4 #include<algorithm> 5 #include<stdlib.h> 6 #incl

luogu_4317: 花神的数论题

花神的数论题 题意描述: 设\(sum(i)\)表示\(i\)的二进制数中\(1\)的个数. 给定一个整数\(N\),求\(\prod_{i=1}^Nsum(i)\). 输入描述: 输入包含一个正整数\(N(N\leq10^{15})\). 输出描述: 一个数,答案模\(10000007\)的值. 解题思路: 数位\(dp\)+快速幂. 令\(f(i,j,k)\)表示以\(k\)开头的\(i\)位数中\(1\)的个数为\(j\)的数量.有转移方程 \(f(i,j,0)=f(i-1,j,0)+f(