操作序列:简单的二维 dp。

观察

我们每次操作可以让 \(x\) 变为 \(2x-1\),或者当 \(x\) 为奇数时让 \(x\) 变为 \(\frac{x+1}{2}\)。

显然,执行第一种操作,会使 \(x\) 变成奇数。

那一旦我们连续执行两次操作,\(x\) 就会变为:

\[\frac{(2x+1)-1}{2}=\frac{2x}{2}=x
\]

也就是说,当 \(x\) 为奇数时,这两个操作互逆。当 \(x\) 为偶数时,无法操作。

因此,在任何时候,第一次操作的次数都要大于等于第二次操作的次数。这像极了括号匹配,任何时候左括号必须大于右括号。

其中左括号是操作 \(1\),右括号是操作 \(2\)。

dp 设计

于是我们可以先在 \(x\) 为奇数时把 \(x\) 不断执行第二种操作直到变成偶数,相当于往栈里丢了几个左括号。

然后接下来我们对每次操作考虑,定义 \(dp_{i,j}\) 表示考虑前 \(i\) 位,目前栈里有 \(j\) 个左括号的方案数。

然后很显然的转移:

\[dp_{i,j}=\sum_{j=1}^{n+s}dp_{i-1,j-1}+\sum_{j=0}^{n+s-1}dp_{i-1,j+1}
\]

其中 \(s\) 表示一开始加进栈里面的左括号个数。

时间复杂度 \(O(n^2)\),可过。

其实这题可以用滚动数组优化,但是不用滚动数组仍然可以过。因为我懒,就不写滚动数组了。

特判

注意到当最后 \(x\) 能变成 \(1\) 时,无论何时使用操作 \(1\) 或者操作 \(2\) 都可以。于是此时答案就是 \(2^n\)。

代码

#include <bits/stdc++.h>
#define fi first
#define se second
#define lc (p<<1)
#define rc ((p<<1)|1)
using namespace std;
typedef long long ll;
typedef pair<int,int> pi;
const ll mod=998244353;
ll dp[5005][6005],n,s,ans=0;
int main()
{
freopen("op.in","r",stdin);
freopen("op.out","w",stdout);
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
cin>>n>>s;
int tmp=s,qs=0;
while(tmp%2==1&&tmp>1)
{
tmp=(tmp+1)/2;
qs++;
}
if(tmp!=1)
{
dp[0][qs]=1;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=6000;j++)
{
dp[i][j]=(dp[i-1][j-1]+dp[i][j])%mod;
}
for(int j=0;j<=6000;j++)
{
dp[i][j]=(dp[i][j]+dp[i-1][j+1])%mod;
}
}
for(int i=0;i<=6000;i++)ans=(ans+dp[n][i])%mod;
cout<<ans%mod;
return 0;
}
dp[0][0]=1;
for(int i=1;i<=n;i++)dp[i][0]=(dp[i-1][0]*2)%mod;
cout<<dp[n][0];
return 0;
}

坑点

dp 转移上限不能直接设为 \(n\),因为一开始会多丢 \(\log\) 个左括号进去。

Hetao P1391 操作序列 题解 [ 绿 ] [ 二维线性 dp ]的更多相关文章

  1. Vijos1392拼拼图的小衫[背包DP|二维信息DP]

    背景 小杉的幻想来到了经典日剧<死亡拼图>的场景里……被歹徒威胁,他正在寻找拼图(-.-干嘛幻想这么郁闷的场景……). 突然广播又响了起来,歹徒竟然又有了新的指示. 小杉身为新一代的汤浅, ...

  2. UVA1347 旅游(二维递归DP)

    旅游 [题目链接]旅游 [题目类型]DP &题解: 紫书P269 代码很简单,但思路很难.很难能想到要把一个圈分成2条线段,很难想到d(i,j)表示的是已经走过max(i,j)还需要的距离值, ...

  3. 二维线性表 list实现

    class Coordinate{ private int x; private int y; } List<Coordinate> list=new ArrayList<Coord ...

  4. 棋盘分割(二维区间DP)

    题目大意:给一个棋盘,棋盘上每个格子中都有一个值,现在需要将棋盘切成n个矩形,总共切n-1刀,求最小的均方差.均方差定义为:,其中. 题目分析:将均方差化简得到:均方差2=(Σxi2)/n-平均值2. ...

  5. 在UniApp的H5项目中,生成二维码和扫描二维码的操作处理

    在我们基于UniApp的H5项目中,需要生成一些二维码进行展示,另外也需要让用户可以扫码进行一定的快捷操作,本篇随笔介绍一下二维码的生成处理和基于H5的扫码进行操作.二维码的生成,使用了JS文件wea ...

  6. HDU 4819 Mosaic 二维线段树

    Mosaic Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudge/contest/view.action ...

  7. poj2155二维树状数组

    Given an N*N matrix A, whose elements are either 0 or 1. A[i, j] means the number in the i-th row an ...

  8. Android应用--QR的生成(二维码)

    二维码的定义: 二维码(2-dimensional bar code),是用某种特定的几何图形按一定规律在平面(二维方向上)分布的黑白相间的图形记录数据符号信息的. 在许多种类的二维条码中,常用的码制 ...

  9. 低差异序列 (low-discrepancy sequences)之Halton序列均匀产生多维随机数的介绍与实现

    Halton序列 在统计学中,Halton序列是用于生成空间中的点的序列,如Monte Carlo模拟的数值方法,虽然这些序列是确定性的,但它们的差异性很低,也就是说,在许多方面看起来是随机的.它们在 ...

  10. PHP二维码生成的方法(google APi,PHP类库,libqrencode等)

    原文地址: http://blog.csdn.net/liuxinmingcode/article/details/7910975 ================================== ...

随机推荐

  1. Mac 上常见的环境配置文件

    当使用命令行终端进行开发时,环境配置文件可以用来自动化执行一些命令或设置环境变量,以提高工作效率和方便使用.在 Mac 上,常见的环境配置文件有以下几种: 1. 在.bash_profile文件中配置 ...

  2. laravel之验证器

    开发中使用框架自带验证器进行参数验证 1.定义验证器基类,定义失败返回值 新建基础类文件 app > Http > Requests > BaseRequest.php <?p ...

  3. AtCoder Beginner Contest 379

    Contest Link C 妙妙贪心题,居然需要高斯求和公式. Submission D 妙妙套路题,维护全局 lazytag,easy to solve. Submission E 妙妙拆贡献题, ...

  4. Jenkis 简单介绍—持续集成、持续交付的工具

    Jenkis是什么? 首先是一款持续集成.持续交付的工具. Jenkis的思想是自动化部署:当我们向版本库提交最新的代码后,应用服务器(tomcat)就会自动从Git / svn上拉取最新的包,再重新 ...

  5. MAC清理

    今日分享 Mac清理 有很多三方软件可以清理,以前用过腾讯的柠檬lite,每次就清个几百兆,系统数据感觉还是得自己手动清理才行 今天电脑又在提醒储存空间不足了,一看占用发现系统数据占了100多个G,学 ...

  6. 【Java】【SpringBoot】CP02:单元测试

    This article is written by Xrilang(Chinese Name:萌狼蓝天) If you want find me ,You can contact me in Bil ...

  7. 【MyBatis】学习笔记13:延迟加载(懒加载)

    目录 Mybatis13:延迟加载(懒加载) 测试 测试1 测试2 部分特殊情况处理 Mybatis13:延迟加载(懒加载) 延迟加载是分步查询的好处,默认是不开启延迟加载的,要开启需要在核心配置文件 ...

  8. com.sun.xml.internal.messaging.saaj.util 不存在

    maven 编译时报错:程序包com.sun.xml.internal.messaging.saaj.util不存在需要添加 <compilerArguments> <verbose ...

  9. 【FAQ】HarmonyOS SDK 闭源开放能力 — Vision Kit(2)

    1.问题描述: 人脸活体检测返回上一页App由沉浸式变为非沉浸式多了上下安全区域. 解决方案: 检测结束后需要自己去设置沉浸式配置. 2.问题描述: Vision Kit文字识别是本地识别,还是上传至 ...

  10. .NET 中的线程安全数据结构

    目录 1. ConcurrentQueue 2. ConcurrentStack 3. ConcurrentBag 4. ConcurrentDictionary<TKey, TValue> ...