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(i-1,j,1)\)
- \(f(i,j,1)=f(i-1,j-1,0)+f(i-1,j-1,1)\)
- 这个很好理解,就是往最高位填\(0/1\)。
- 设\(sum(i)==x\)的\(i\)有\(tot\)个,那么他对答案的贡献显然就是\(x^{tot}\)。
- 所以这时候枚举\(x\)就行,显然对于\(N(N\leq 10^{15})\)而言,不会枚举超过\(60\)次。
- 详见代码:
代码:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn = 70, mod = 10000007;
ll f[maxn][maxn][2];
ll n, ans;
inline ll qmi(ll a, ll b)
{
ll res = 1;
while(b)
{
if(b & 1) res = (res * a) % mod;
a = (a * a) % mod;
b >>= 1ll;
} return res % mod;
}
//x对应的二进制中有多少个1
inline ll len(ll x)
{
ll res = 0;
while(x)
{
if(x & 1ll) res++;
x >>= 1ll;
}
return res;
}
int num[maxn], cnt;
inline void work(ll x)
{
cnt = 0; ans = 1;
while(x) //分解数位
{
num[++cnt] = x&1;
x >>= 1;
}
//枚举m, 求出有多少i,有sum(i)=m
for(int m = 1; m <= cnt; m++)
{
for(int i = 1; i < cnt; i++)
ans = (ans * qmi(m, f[i][m][1]) % mod) % mod;
//先枚举位数比n要小的数
//开始处理位数和n相同的数字
int k = m;
//如果n的最高位是1的话
//其实相当于把最高位固定了
if(num[cnt]) k--;
//从高位往低位枚举
//之后我们让第i位小于n的第i位
//这样可以让第i位后面的数字随便填写
for(int i = cnt - 1; i >= 1; i--)
{
for(int j = 0; j < num[i]; j++)
ans = (ans * qmi(m, f[i][k][j]) % mod) % mod;
if(num[i]) k--; //相当于把第i位固定 因为i有1 所以k--
if(k < 0) break;
}
}
//由于一直卡上界,所以其实一直没有遇到等于n的情况
//所以最后对n暴力分解数位处理一下
ans = ((ans % mod) * (len(n) % mod)) % mod;
printf("%lld\n", ans);
}
inline void init()
{
scanf("%lld", &n);
//dp预处理
f[1][0][0] = f[1][1][1] = 1;
for(int i = 1; i <= 60; i++)
{
for(int j = 0; j <= i; j++)
{
f[i+1][j+1][1] += f[i][j][0] + f[i][j][1];
f[i+1][j][0] += f[i][j][0] + f[i][j][1];
}
} work(n);
}
int main()
{
init();
return 0;
}
luogu_4317: 花神的数论题的更多相关文章
- BZOJ 3209: 花神的数论题 [数位DP]
3209: 花神的数论题 题意:求\(1到n\le 10^{15}\)二进制1的个数的乘积,取模1e7+7 二进制最多50位,我们统计每种1的个数的数的个数,快速幂再乘起来就行了 裸数位DP..\(f ...
- 【洛谷】4317:花神的数论题【数位DP】
P4317 花神的数论题 题目背景 众所周知,花神多年来凭借无边的神力狂虐各大 OJ.OI.CF.TC …… 当然也包括 CH 啦. 题目描述 话说花神这天又来讲课了.课后照例有超级难的神题啦…… 我 ...
- 【LG4317】花神的数论题
[LG4317]花神的数论题 题面 洛谷 题解 设\(f_{i,up,tmp,d}\)表示当前在第\(i\)位,是否卡上界,有\(tmp\)个一,目标是几个一的方案数 最后将所有\(d\)固定,套数位 ...
- BZOJ3209 花神的数论题 【组合数学+数位DP+快速幂】*
BZOJ3209 花神的数论题 Description 背景 众所周知,花神多年来凭借无边的神力狂虐各大 OJ.OI.CF.TC …… 当然也包括 CH 啦. 描述 话说花神这天又来讲课了.课后照例有 ...
- [BZOJ3209]花神的数论题 组合数+快速幂
3209: 花神的数论题 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2498 Solved: 1129[Submit][Status][Disc ...
- 【BZOJ3209】花神的数论题 数位DP
[BZOJ3209]花神的数论题 Description 背景众所周知,花神多年来凭借无边的神力狂虐各大 OJ.OI.CF.TC …… 当然也包括 CH 啦.描述话说花神这天又来讲课了.课后照例有超级 ...
- 【bzoj3209】: 花神的数论题 数论-DP
[bzoj3209]: 花神的数论题 首先二进制数中1的个数最多就是64个 设所有<=n的数里二进制中1的个数为i的有a[i]个 那么答案就是 然后快速幂 求a[i]可以用DP 设在二进制中从 ...
- bzoj3209:3209: 花神的数论题
觉得还是数位dp的那种解题形式但是没有认真的想,一下子就看题解.其实还是设置状态转移.一定要多思考啊f[i][j]=f[i-1][j]+g[i-1][j] g[i][j]=f[i-1][j-1]+g[ ...
- [Bzoj3209]花神的数论题(数位dp)
3209: 花神的数论题 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2633 Solved: 1182[Submit][Status][Disc ...
随机推荐
- Marshmallow详解
目录 Marshmallow详解 1. Scheme 2. Serializing(序列化) 3. 过滤输出 4. Deserializing(反序列化) 5. 处理多个对象的集合 6. Valida ...
- Linux学习笔记之rpm包管理功能全解
0x00 软件包管理器 所有的软件都是由文件格式的程序代码(即源代码),经过编译成为一个可执行二进制文件:对于一个软件来说,其包含二进制程序.库文件.配置文件以及帮助文件.在应用中,每次要安装程序时通 ...
- SQL Server外键关系是强制约束,外键值也可以是空(NULL)
在SQL Server中,实际上外键值可不可以为空(NULL),和外键关系是不是强制约束无关. 我们先在SQL Server数据库中建立两张表People和Car,一个People可以有多个Car,所 ...
- EF之DataBase添加新表
由于需要新增的XML数据较多,可以另起项目,将新增的XML数据复制到原来的EF
- 剑指offer之面试题2:实现Singleton模式
来源:剑指offer 这篇主要记录<剑指offer>书籍中的面试题2:实现Singleton模式 使用语言:C# 代码环境:VS2017 总共有5中解法,从前往后依次优化. 结构如下: 前 ...
- Ubuntu18.04 配置网卡、替换软件源
2019/10/29, Ubuntu Server 18.04 摘要:Ubuntu Server 18.04 采用netplan作为网络配置管理,修改IP使其连上网络,修改替换软件源 修改网卡配置 首 ...
- python基础--py2与py3编码
python2 与 python3的编码和解码 注意:小心,容易弄混 目录: 1.python2d 的encode & decode 2.python3的encode & decode ...
- Matlab享元模式
享元模式(Flyweight)通过共享技术实现相同或相似对象的重用,可以减少创建对象的数量,以减少内存占用和提高性能.Java String的常量池,python logging,线程池,数据库连接池 ...
- Leetcode 297. Serialize and Deserialize Binary Tree
https://leetcode.com/problems/serialize-and-deserialize-binary-tree/ Serialization is the process of ...
- React的基本知识和优缺点
阮一峰 React入门实例教程 知识点 1.html模板3个预加载的js文件,script的type属性 2.ReactDOM.render() 3.JSX语言:允许js和html的混写 4.comp ...