「SDOI2016」储能表(数位dp)

神仙数位 \(dp\) 系列 可能我做题做得少 \(QAQ\)

\(f[i][0/1][0/1][0/1]\) 表示第 \(i\) 位 \(n\) 是否到达上界 \(m\) 是否到达上界 \(k\) 是否到达下界。我用一个 \(pair\) 存,\(first\) 记录方案数,\(second\) 记录所有的和。

\(ans=(P.S-k*P.F)\%mod\)

那么我们每次枚举该位为 \(0/1\) 就可以转移了,逐位计算贡献。

\(Code\ Below:\)

#include <bits/stdc++.h>
#define ll long long
#define pll pair<ll,ll>
#define mp make_pair
#define F first
#define S second
using namespace std;
ll n,m,k,mod;pll f[70][2][2][2];
bool vis[70][2][2][2]; pll dfs(int len,bool N,bool M,bool K){
if(len<0) return mp(1,0);
if(vis[len][N][M][K]) return f[len][N][M][K];
vis[len][N][M][K]=1;
pll ret=mp(0,0),P;
bool lim_n=N?(n>>len)&1:1,lim_m=M?(m>>len)&1:1,lim_k=K?(k>>len)&1:1;
for(int i=0;i<=lim_n;i++)
for(int j=0;j<=lim_m;j++){
if(K&&(i^j)<lim_k) continue;
P=dfs(len-1,N&&i==lim_n,M&&j==lim_m,K&&(i^j)==lim_k);
ret.F=(ret.F+P.F)%mod;
ret.S=(ret.S+P.S+(i^j)*(1ll<<len)%mod*P.F)%mod;
}
return f[len][N][M][K]=ret;
} inline void solve(){
memset(f,0,sizeof(f));
memset(vis,0,sizeof(vis));
scanf("%lld%lld%lld%lld",&n,&m,&k,&mod);
n--;m--;
ll N=n,M=m,K=k;int Max=0,now=0;
while(N) N>>=1,now++;Max=max(Max,now);now=0;
while(M) M>>=1,now++;Max=max(Max,now);now=0;
while(K) K>>=1,now++;Max=max(Max,now);now=0;
pll P=dfs(Max-1,1,1,1);
printf("%lld\n",(P.S-k%mod*P.F%mod+mod)%mod);
} int main()
{
int T;
scanf("%d",&T);
while(T--) solve();
return 0;
}

「SDOI2016」储能表(数位dp)的更多相关文章

  1. loj2030 「SDOI2016」储能表

    ref ref 一个点就是一个数对 \((x,y)\). 记状态 \(f[i][1/0][1/0][1/0]\) 和 \(g[i][1/0][1/0][1/0]\),其中三个 \(1/0\) 取值分别 ...

  2. BZOJ 4513: [Sdoi2016]储能表 [数位DP !]

    4513: [Sdoi2016]储能表 题意:求\[ \sum_{i=0}^{n-1}\sum_{j=0}^{m-1} max((i\oplus j)-k,0) \] 写出来好开心啊...虽然思路不完 ...

  3. 【BZOJ4513】[Sdoi2016]储能表 数位DP

    [BZOJ4513][Sdoi2016]储能表 Description 有一个 n 行 m 列的表格,行从 0 到 n−1 编号,列从 0 到 m−1 编号.每个格子都储存着能量.最初,第 i 行第 ...

  4. BZOJ.4513.[SDOI2016]储能表(数位DP)

    BZOJ 洛谷 切了一道简单的数位DP,终于有些没白做题的感觉了...(然而mjt更强没做过这类的题也切了orz) 看部分分,如果\(k=0\),就是求\(\sum_{i=0}^n\sum_{j=0} ...

  5. [SDOI2016]储能表——数位DP

    挺隐蔽的数位DP.少见 其实减到0不减了挺难处理.....然后就懵了. 其实换个思路: xor小于k的哪些都没了, 只要留下(i^j)大于等于k的那些数的和以及个数, 和-个数*k就是答案 数位DP即 ...

  6. 4513: [Sdoi2016]储能表 数位DP

    国际惯例的题面: 听说这题的正解是找什么规律,数位DP是暴力......好的,我就写暴力了QAQ.我们令f[i][la][lb][lc]表示二进制从高到低考虑位数为i(最低位为1),是否顶n上界,是否 ...

  7. BZOJ4513: [Sdoi2016]储能表(数位dp)

    题意 题目链接 Sol 一点思路都没有,只会暴力,没想到标算是数位dp??Orz 首先答案可以分成两部分来统计 设 \[ f_{i,j}= \begin{aligned} i\oplus j & ...

  8. [bzoj4513][SDOI2016]储能表——数位dp

    题目大意 求 \[\sum_{i = 0}^{n-1}\sum_{j=0}^{m-1} max((i\ xor\ j)\ -\ k,\ 0)\ mod\ p\] 题解 首先,开始并没有看出来这是数位d ...

  9. LG2602/BZOJ1833 「ZJOI2010」数字计数 数位DP

    问题描述 LG2602 BZOJ1833 题解 数位\(\mathrm{DP}\)板子题. 注意限制位数.前导零. \([a,b]=[1,b]-[1,a-1]\) \(\mathrm{Code}\) ...

随机推荐

  1. 试了下阿里云的OPEN Api

    逐渐理解open api的意义,试了下阿里云的续费接口,续费一个月 package com.test; /** * @author * @date 2018/12/05 */ import com.a ...

  2. linux查看磁盘大小df命令

    df -h https://www.cnblogs.com/sparkdev/p/9273094.html

  3. springboot+mybatis+freemark+oauth开发环境搭建

    一.创建springboot工程 1.环境介绍: a:jdk版本:1.7 b:Springboot版本:1.5.6(使用1.5.9的版本整合mybatis会报错:java.lang.NoClassDe ...

  4. SQLyog简介及其功能(附百度云盘下载地址)

    一.软件简介 SQLyog 是一个快速而简洁的图形化管理MYSQL数据库的工具,它能够在任何地点有效地管理你的数据库.SQLyog是业界著名的Webyog公司出品的一款简洁高效.功能强大的图形化MyS ...

  5. springboot @scheduled 并发

    本文介绍如何使用springboot的sheduled实现任务的定时调度,并将调度的任务实现为并发的方式. 1.定时调度配置scheduled 1)注册定时任务 package com.xiaoju. ...

  6. Linux shell read 解析

    read是一个重要的bash命令,它用于从键盘或标准输入中读取文本,我们可以用read以交互的方式读取来自用户的输入,不过read能做的可远不止这些,当从键盘读取用户输入的时候,只有按下回车键才标志输 ...

  7. WIN10在loadrunner安装或path4插件安装时遇到的管理员阻止程序运行---解决方案(可用)

    方法1:关闭用户账户控制1.“win+x”进入控制面板,选择安全性与维护,在左侧更改windows smartscreen筛选器设置,选择"不执行任何操作",单击确定即可.2.“w ...

  8. [leetcode]80. Remove Duplicates from Sorted Array II有序数组去重(单个元素可出现两次)

    Given a sorted array nums, remove the duplicates in-place such that duplicates appeared at most twic ...

  9. ES6 Iterator

    不同数据集合怎么用统一的方式读取 可以用for...of循环了

  10. 前后端跨域 _ cross domain

    1. 解决跨域既可以从前端, 也可以从后端. 参考好的网络资源: http://www.cnblogs.com/vajoy/p/4295825.html