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 ...
随机推荐
- 在Windows 10中禁用自动文件夹类型发现
点击下载注册表文件:https://files.cnblogs.com/files/Music/win10_automatic_folder_type_discovery.zip 已知Windows ...
- docker 的Portainer和Dive
Portainer Portainer是Docker的图形化管理工具,提供状态显示面板.应用模板快速部署.容器镜像网络数据卷的基本操作(包括上传下载镜像,创建容器等操作).事件日志显示.容器控制台操作 ...
- 开源规则引擎 Drools 学习笔记 之 -- 1 cannot be cast to org.drools.compiler.kie.builder.impl.InternalKieModule
直接进入正题 我们在使用开源规则引擎 Drools 的时候, 启动的时候可能会抛出如下异常: Caused by: java.lang.ClassCastException: cn.com.cheng ...
- ASP.NET中App_Data等文件夹的作用
文件夹名称 文件类型 注 释 Bin .dll 包含应用程序所需的任何预生成的程序集 App_Browsers .browser 包含应用程序特有的浏览器定义文件,ASP.NET用它来识别各浏览器 ...
- Centos7安装Tomcat7,并上传JavaWeb项目
一.需要的工具(其他连接工具也行) 1.Xshell 2.XFTP 1.1首先将Tomcat7的压缩文件利用XFTP上传到Centos7系统上的 /etc/local/tomcat中 1.2 解压文件 ...
- loj#10078. 新年好(最短路)
题目: loj#10078. 新年好 解析: 亲戚只有五个,可以把它们看成2,3,4,5,6号点,分别跑最短路,记录一下距离,然后DFS一下 这题非常玄学,我开了一个\(12*12\)的数组,没有离散 ...
- Django--FBV + CBV
目录 FBV + CBV FBV(function bases views) FBV中加装饰器相关 CBV(class bases views) CBV中加装饰器相关 FBV + CBV django ...
- ASP.NET Core 2.2在中间件内使用有作用域的服务
服务生存期 为每个注册的服务选择适当的生存期.可以使用以下生存期配置ASP.NET Core服务: 暂时 暂时生存期服务 (AddTransient) 是每次从服务容器进行请求时创建的. 这种生存期适 ...
- Java语法知识点2
1. 基本数据类型的包装类 byte Byte short Short int Integer long Long float Float double Double boolea ...
- MySQL Table--MySQL外键
在之前的MySQL运维中,要求禁用触发器/存储过程/外键等一些数据库常见功能,因此对MySQL外键也相对比较陌生,今天特地探究下. 现有表TB001和TB002各包含6291456行数据,创建脚本如下 ...