BZOJ3209: 花神的数论题

3209: 花神的数论题

Time Limit: 10 Sec  Memory Limit: 128 MB
Submit: 689  Solved: 334
[Submit][Status]

Description

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

Input

一个正整数 N。

Output

一个数,答案模 10000007 的值。

Sample Input

样例输入一

3

Sample Output

样例输出一

2

HINT

对于样例一,1*1*2=2;

数据范围与约定

对于 100% 的数据,N≤10^15

Source

原创 Memphis

题解:

晚上做题各种不爽,明明想出了正解,一直WA,等A了在写题解吧。。。

代码:

1.自己yy的,虽然慢,但AC没问题

 1 #include<cstdio>
 2 #include<cstdlib>
 3 #include<cmath>
 4 #include<cstring>
 5 #include<algorithm>
 6 #include<iostream>
 7 #include<vector>
 8 #include<map>
 9 #include<set>
10 #include<queue>
11 #define inf 1000000000
12 #define maxn 100
13 #define maxm 500+100
14 #define mod 10000007
15 #define ll long long
16 #define pa pair<int,int>
17 using namespace std;
18 ll ans,n,c[maxn][maxn],tot,sum,a[maxn];
19 ll power(ll x,ll y)
20 {
21     ll t;
22     for(t=1;y;y>>=1,x*=x,x%=mod)
23      if(y&1){t*=x;t%=mod;}
24     return t;
25 }
26 ll dp(int sum,int x)
27 {
28     ll t=1,w;
29     for(int i=0;i<=x;i++)
30      {
31       w=power(sum+i,c[x][i]);
32       if(w)t*=w,t%=mod;
33      }
34     return t;
35 }
36 int main()
37 {
38     freopen("input.txt","r",stdin);
39     freopen("output.txt","w",stdout);
40     while(cin>>n)
41     {
42     tot=0;
43     c[0][0]=1;
44     for(int i=1;i<=64;i++)
45      {
46          c[i][0]=1;c[i][i]=1;
47          for(int j=1;j<=i-1;j++)c[i][j]=(c[i-1][j-1]+c[i-1][j])% mod;
48      }
49     while(n){a[++tot]=n%2;n>>=1;}
50     ans=1;sum=0;
51     for(int i=tot;i>0;i--)
52     if(a[i])
53      {
54       ans*=dp(sum,i-1);ans%=mod;sum++;
55      }
56     ans*=sum;ans%=mod;
57     printf("%lld\n",ans);
58     }
59     return 0;
60 }

2.网上的,自己抄都不对?

 1 #include<cstdio>
 2 #include<cstdlib>
 3 #include<cmath>
 4 #include<cstring>
 5 #include<algorithm>
 6 #include<iostream>
 7 #include<vector>
 8 #include<map>
 9 #include<set>
10 #include<queue>
11 #define inf 1000000000
12 #define maxn 100
13 #define maxm 500+100
14 #define mod 10000007
15 #define ll long long
16 #define pa pair<int,int>
17 using namespace std;
18 ll ans,n,c[maxn][maxn],tot,sum,a[maxn];
19 ll power(ll x,ll y)
20 {
21     ll t;
22     for(t=1;y;y>>=1,x*=x,x%=mod)
23      if(y&1){t*=x;t%=mod;}
24     return t;
25 }
26 ll calc(int x)
27 {
28    ll t=0;
29    for(int i=tot;i&&x>=0;i--)
30     if(a[i])t+=c[i-1][x--];
31    return t;
32 }
33 int main()
34 {
35     freopen("input.txt","r",stdin);
36     freopen("output.txt","w",stdout);
37     while(cin>>n)
38     {
39     n++;
40     tot=0;
41     c[0][0]=1;
42     for(int i=1;i<=64;i++)
43      {
44          c[i][0]=1;c[i][i]=1;
45          for(int j=1;j<=i-1;j++)c[i][j]=(c[i-1][j-1]+c[i-1][j])% mod;
46      }
47     while(n){a[++tot]=n%2;n>>=1;}
48     ans=1;
49     for(int i=1;i<=tot;i++)ans*=power(i,calc(i)),ans%=mod;
50     printf("%lld\n",ans);
51     }
52     return 0;
53 }

时间: 2024-10-15 07:51:54

BZOJ3209: 花神的数论题的相关文章

【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: 花神的数论题

觉得还是数位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(

【BZOJ3209】花神的数论题 数位DP(我姿势不标准,但是可能更好写)

#include <stdio.h> int main() { puts("转载请注明出处谢谢"); puts("http://blog.csdn.net/vmurder/article/details/43370607"); } 题解: 数位DP无疑.注:下面说的位基本都是二进制. f[i][j]表示前i位数中有j个1的数的数量(包括0哦~) 然后一个低位数后面填0/1分别是两种向高位的转移,这样在O(log^2 n)时间内处理出f 主要是我的姿势(嗯