牛客练习赛35-背单词-线性DP
思路 :dp[ i ] [ 0 ]表示 第i 位放的元音 dp[ i ] [ 1 ]表示 第i 位放的辅音 ,cnt [ i ]含义是 长度为 i 的方案数。
转移 :dp[ i ] [ 0 ] 由 上一个长度的所有方案数 也就是 cnt[ i-1 ] *5 转移而来 。
同理 dp[ i ] [ 1 ] 由 上一个长度的所有方案数 也就是 cnt[ i-1 ] *21 转移而来 。
但是 这是 无任何限制的情况下现在加了限制,连续 元音不超过 a 连续 辅音不超过 b
那么 首先 长度得 > a 或 > b 才会出现这种情况。 那么,当长度i = a +1 时 照常运算dp[ i ] [ 0 ] ,
但是需要减去 产生了 a + 1个元音相连的情况 。 也就是减去 dp[ i - a - 1][ 1 ] * pa 。pa是连续a+1 个元音的各种组合方案数
dp[ i - a - 1][ 1 ] 是去掉 a + 1的长度 之前 最后一个字母为辅音的状态。
同理 当长度i = b +1 时 照常运算dp[ i ] [ 1 ] ,但是需要减去 产生了 b + 1个元音相连的情况 。
也就是减去 dp[ i - b - 1][ 0 ] * pb 。pb是连续b+1 个辅音的各种组合方案数
dp[ i - b - 1][ 0 ] 是去掉 b + 1的长度 之前 最后一个字母为元音的状态。
不会 出现 a + 2 a + 3.....个元音相连,b+2,b + 3 .....个辅音相连 ,因为 a + 1个 元音相连 ,b +1 个辅音相连的情况,
都已经去掉了 ,长度一个一个增加不会产生 b + 2 ,a + 2 后面的也就更不会产生 。
ans 不断 求和 各个长度下的 方案数。
#include<bits/stdc++.h>
using namespace std;
const int mod=1000000007;
#define ll long long
#define maxn 5678
ll pa,pb,dp[maxn][2],cnt[maxn],ans;
int t,n,a,b;
ll qpow(ll a,ll b)
{
ll ret=1;
while(b)
{
if(b%2)
ret=(ret*a)%mod;
a=(a*a)%mod;
b/=2;
}
return ret;
}
int main()
{
dp[0][0]=dp[0][1]=1;
dp[1][0]=5,dp[1][1]=21;
cnt[1]=26;
scanf("%d",&t);
while(t--)
{
ans=26;
scanf("%d%d%d",&n,&a,&b);
pa=qpow(5,a+1);
pb=qpow(21,b+1);
for(int i=2; i<=n; i++)
{
dp[i][0]=5*cnt[i-1]%mod;
dp[i][1]=21*cnt[i-1]%mod;
if(i>a) dp[i][0]=(dp[i][0]-dp[i-a-1][1]*pa+mod)%mod;
if(i>b) dp[i][1]=(dp[i][1]-dp[i-b-1][0]*pb+mod)%mod;
cnt[i]=(dp[i][0]+dp[i][1])%mod;
ans=(ans+cnt[i]+mod)%mod;
}
printf("%lld\n",ans);
}
return 0;
}
牛客练习赛35-背单词-线性DP的更多相关文章
- 牛客练习赛52 | C | [烹饪] (DP,裴蜀定理,gcd)
牛客练习赛52 C 烹饪 链接:https://ac.nowcoder.com/acm/contest/1084/C来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 327 ...
- 牛客练习赛26B 烟花 (概率DP)
链接:https://ac.nowcoder.com/acm/contest/180/B 来源:牛客网 烟花 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言5 ...
- 牛客练习赛35 C.函数的魔法
链接 [https://ac.nowcoder.com/acm/contest/32] 题意 题目描述 一位客人来到了此花亭,给了女服务员柚一个数学问题:我们有两个函数,F(X)函数可以让X变成(XX ...
- 牛客练习赛37-筱玛的字符串-DP递推
筱玛的字符串 思路 :dp [ i ] [ j ] [ 3 ] 分别代表到第 i 位时 左括号比右括号多 j ,后面有三个状态 分别表示当前位置 S3的字符 是正在反转的,还是 反转完成的,还是没有反 ...
- 牛客练习赛71 数学考试 题解(dp)
题目链接 题目大意 要你求出有多少个长度为n的排列满足m个限制条件 第i个限制条件 p[i]表示前 p[i]个数不能是1-p[i]的排列 题目思路 这个感觉是dp但是不知道怎么dp 首先就是要明白如果 ...
- 牛客练习赛69 火柴排队 题解(dp)
题目链接 题目大意 给你一个长为n(n<=5e3)的数组a.随机使得k个元素增加d.要你求多大的概率使得,这些数组元素的相对大小不发生改变 输出 n 行每行一个整数,第 i 行的整数表示 k=i ...
- 牛客练习赛71 C.数学考试 (DP,容斥原理)
题意:RT 题解:先对\(p\)排个序,然后设\(dp[i]\)表示前\(i-1\)个\(p[i]\)满足条件但是\(p[i]\)不满足,即在\([1,p[i]]\)中不存在从\(p[1]\)到\(p ...
- 牛客练习赛39 C 流星雨 (概率dp)
题意: 现在一共有n天,第i天如果有流星雨的话,会有wi颗流星雨. 第1天有流星雨的概率是p1. 如果第i−1 (i≥2)天有流星雨,第i天有流星雨的可能性是pi+P,否则是pi. 求n天后,流星雨颗 ...
- 牛客练习赛26:D-xor序列(线性基)
链接:牛客练习赛26:D-xor序列(线性基) 题意:小a有n个数,他提出了一个很有意思的问题:他想知道对于任意的x, y,能否将x与这n个数中的任意多个数异或任意多次后变为y 题解:线性基 #inc ...
- 牛客练习赛53 A 超越学姐爱字符串 (DP)
牛客练习赛53 超越学姐爱字符串 链接:https://ac.nowcoder.com/acm/contest/1114/A来源:牛客网 超越学姐非常喜欢自己的名字,以至于英文字母她只喜欢" ...
随机推荐
- 巧用&&和|| 让逻辑代码更简洁,逼格看起来更高一点(玩笑脸)
通常当我们有一个需求 需要用到很多if else 进行条件筛选,例如: let level = 0; if(score > 12){ level = 4; } else if(score > ...
- libopencv_highgui.so.2.4.9:对‘TIFFReadRGBAStrip@LIBTIFF_4.0’未定义的引用
make之前加上sudo su重新make即可 http://blog.csdn.net/cfyzcc/article/details/52981467
- Java的家庭记账本程序(F)
日期:2019.2.17 博客期:034 星期日 我先配置了Android的相关环境,先试着做了Hello World的测试,但是却出现了很严重的问题,问题如下: Unable to get curr ...
- Let the Balloon Rise <map>的应用
Contest time again! How excited it is to see balloons floating around. But to tell you a secret, the ...
- Brup Suite 渗透测试笔记(六)
接上次笔记这章记payload的类型分类做一说明: 1.simplelist是一个简单的payload类型,通过配置一个字符串作为payload,也可以手动添加字符串列表. 2.运行文件 Runtim ...
- 图像特征的提取(gaussian,gabor,frangi,hessian,Morphology...)及将图片保存为txt文件
# -*- coding: utf-8 -*- #2018-2-19 14:30:30#Author:Fourmi_gsj import cv2 import numpy as np import p ...
- centos/redhat破解账号密码
说明:1.个人觉得centos系统和redhat系统差不多,界面都差不多一样. 2.下面方法用于开机root密码忘了,其他人篡改root密码等等 下面是破解账号密码(图解) 之后要等久点 效果: 方法 ...
- Linux-server-sshd
Linux-server-sshd 1:安装 OpenSSH 服务需要4 个软件包 openssh-5.3p1-114.el6_7.x86_64:包含OpenSSH 服务器及客户端需要的核心文件 op ...
- Visual Studio 2017 IDE之xml过大报错
XML处理时遇到这个错误 在powershell中输入 $vsWherePath = Join-Path ${env:ProgramFiles(x86)} "Microsoft Visual ...
- 关于64位 MS SQL 导入导出 Oracle 引发 ORA-06413 的解决方法
如果在X64系统下我们想利用 MS SQL 的DTS导入导出 Oracle 数据,由 oracle 不支持路径中包含")",会引发 ORA-06413:连接未打开错误 解决的办法很 ...