水一些dp的联系题

标签: dp


hdu_2045

  • 题意

一穿珠子,用三种颜色染色,要求相邻的珠子和两端的珠子不能是同一种颜色,求当有n个珠子的时候有几种染色方案

  • 题解

表示dp[i][j][k] 表示开始位置为k当前i位置为j的最大值

  • 代码

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define ll long long
ll dp[55][3][3];//dp[i][j][k] 表示开始位置为k当前i位置为j的最大值 void init()
{
dp[0][0][0] = dp[0][1][1] = dp[0][2][2] = 1;
dp[0][1][0] = dp[0][2][0] = dp[0][0][1] = dp[0][2][1] = dp[0][0][2] = dp[0][1][2] = 0;
for(int i = 1; i < 55; i++){
dp[i][0][0] = dp[i-1][1][0] + dp[i-1][2][0];
dp[i][1][0] = dp[i-1][0][0] + dp[i-1][2][0];
dp[i][2][0] = dp[i-1][1][0] + dp[i-1][0][0]; dp[i][0][1] = dp[i-1][1][1] + dp[i-1][2][1];
dp[i][1][1] = dp[i-1][0][1] + dp[i-1][2][1];
dp[i][2][1] = dp[i-1][1][1] + dp[i-1][0][1]; dp[i][0][2] = dp[i-1][1][2] + dp[i-1][2][2];
dp[i][1][2] = dp[i-1][0][2] + dp[i-1][2][2];
dp[i][2][2] = dp[i-1][1][2] + dp[i-1][0][2];
}
}
int main()
{
init();
int n;
while(~scanf("%d",&n))
{
if(n==1)puts("3");
else
printf("%lld\n",dp[n-1][1][0]+dp[n-1][2][0]+dp[n-1][0][1]+dp[n-1][2][1]+dp[n-1][1][2]+dp[n-1][0][2]);
}
return 0;
}

hdu_1297(大数+递推)

推荐一个对这个题讲解很好的博客:http://blog.sina.com.cn/s/blog_8a24b3a301010nwc.html

下面是这个博客的核心内容:

1.首先,n个人时,假设n个人的组合是合法的,这样的一个合法的组合设为\(f(n)\)

2.为了保证n个人的时候是合法的,讨论一下第n个位置的人的性别

(1)如果第n个人是男性,那么前n-1个人,无论是什么样的组合,显然都是能保证n个人的组合是合法的,所以是\(f(n-1)\)

(2)如果第n个是女性的话,那么第n-1个人的性别必须是女性,这样才能保证n个人的组合是合法的!

然后我们需要考虑前n-2个人在合法与不合法这两种情况下都能使n个人的组合都合法的问题 。

*如果前n-2个人的组合是合法的,那么这个组合为\(f(n-2)\)

*如果前n-2的人的组合是不合法的话,那如果要满足当前的是合法的话,n-1位置一定是F,而且如果是非法的话前面n-2 = F ,n-3 = M 只有这一种情况是可行的。这种情况\(f(n-4)\)就是合法的了。

所以得到的递推公式就是\(f(n)=f(n-1)+f(n-2)+f(n-4)\)

下面是代码:

这里注意一下大数要用java

import java.io.*;
import java.math.*;
import java.util.*;
public class Main
{
public static void main(String []args)
{
Scanner cin = new Scanner(System.in);
Integer N = 1001,i;
BigInteger[] f = new BigInteger[N];
f[1] = BigInteger.valueOf(1);
f[2] = BigInteger.valueOf(2);
f[3] = BigInteger.valueOf(4);
f[4] = BigInteger.valueOf(7);
for(i = 5; i < N; i++){
f[i] = f[i-1].add(f[i-2]).add(f[i-4]);
}
while(cin.hasNext())
{
i = cin.nextInt();
System.out.println(f[i]);
}
}
}

hdu_1159

  • 题意

求最长公共子序列

  • 题解

\(dp[i][j]\)表示第一个字符串扫描到第i 个位置看,第二个字符串扫描到j个位置的最长公共子序列,那么有如果\(s[i]=t[j]\)则满足\(dp[i][j]=dp[i-1][j-1]+1\),否则,有\(dp[i][j] = max(dp[i-1][j],dp[i][j-1])\)

注意两个细节:

1,字符串的编号最好从1开始,这样可以避免初始化字符长度为1的情况。

2,输入的时候数组如果从s+1的地方输入,则求数组长度的时候也要\(len1 = strlen(s+1)\)

下面是代码

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream>
using namespace std;
const int N = 1008;
char s[N];
char t[N];
int dp[N][N];
int main()
{
while(cin>>(s+1)>>(t+1)){
int len1 = strlen(s+1);
int len2 = strlen(t+1);
memset(dp,0,sizeof(dp));
for(int i = 1; i <= len1; i++){
for(int j = 1; j <= len2; j++){
if(s[i]==t[j]) dp[i][j] = max(dp[i-1][j-1]+1,max(dp[i-1][j],dp[i][j-1]));
else dp[i][j] = max(dp[i-1][j],dp[i][j-1]);
}
}
printf("%d\n",dp[len1][len2]);
}
return 0;
}

hdu_2563

题目很简单直接上代码

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int dp[25][3];//dp[i][0]表示第i步向上走。。。
void init()
{
dp[0][1] = dp[0][0] = dp[0][2] = 1;
for(int i = 1; i < 25; i++){
dp[i][0] = dp[i-1][0]+dp[i-1][1]+dp[i-1][2];
dp[i][1] = dp[i-1][0]+dp[i-1][1];
dp[i][2] = dp[i-1][0]+dp[i-1][2];
}
}
int main()
{
int T,n;
init();
scanf("%d",&T);
while(T--)
{
scanf("%d",&n);
printf("%d\n",dp[n-1][0]+dp[n-1][1]+dp[n-1][2]);
}
return 0;
}

hdu_2190

题解

dp[i][j]表示当前列有没有2*2的瓷砖

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream>
using namespace std;
int dp[35];
void init()
{
dp[0] = 1;
dp[1] = 3;
for(int i = 2; i < 35; i++){
dp[i] = dp[i-1]+2*dp[i-2];//dp[i][j]表示当前列有没有2*2的瓷砖
}
}
int main()
{
int T,n;
init();
scanf("%d",&T);
while(T--){
scanf("%d",&n);
printf("%d\n",dp[n-1]);
}
return 0;
}

hdu_2041

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int N = 50;
int dp[N];
void init()
{
dp[0] = 0;
dp[1] = 1;
for(int i = 2; i <= N; i++){
dp[i] = dp[i-1]+dp[i-2];
}
}
int main()
{
init();
int T,m;
scanf("%d",&T);
while(T--){
scanf("%d",&m);
printf("%d\n",dp[m]);
}
return 0;
}

dp水一天的更多相关文章

  1. ACM :漫漫上学路 -DP -水题

    CSU 1772 漫漫上学路 Time Limit: 1000MS   Memory Limit: 131072KB   64bit IO Format: %lld & %llu Submit ...

  2. [poj2247] Humble Numbers (DP水题)

    DP 水题 Description A number whose only prime factors are 2,3,5 or 7 is called a humble number. The se ...

  3. Codeforces 148D 一袋老鼠 Bag of mice | 概率DP 水题

    除非特别忙,我接下来会尽可能翻译我做的每道CF题的题面! Codeforces 148D 一袋老鼠 Bag of mice | 概率DP 水题 题面 胡小兔和司公子都认为对方是垃圾. 为了决出谁才是垃 ...

  4. dp水题 序列问题 (9道)

    9道题.A了8道,A题看题解也没弄懂怎么维护m段子序列的,过一段时间再回来看看     dp试水 47:56:23 125:00:00   Overview Problem Status Rank ( ...

  5. 【BZOJ】1270: [BeijingWc2008]雷涛的小猫(DP+水题)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1270 这完全是一眼题啊,但是n^2的时间挺感人.(n^2一下的级别请大神们赐教,我还没学多少dp优化 ...

  6. 【DP水题】投票问题(二)

    投票问题(一) [试题描述] 欧阳文和欧阳武竞选学联主席,汪梁森负责唱票,共有m+n张,结果欧阳文获胜,已知欧阳文和欧阳武分别获得 m 张票和 n 张票(m>n).现在请你计算在唱票过程中欧阳文 ...

  7. POJ 3254 - Corn Fields - [状压DP水题]

    题目链接:http://poj.org/problem?id=3254 Time Limit: 2000MS Memory Limit: 65536K Description Farmer John ...

  8. zzuli1985(dp/水dfs郑轻比赛)

    再一次感受到dp的威力 1985: 即将到来的新生赛 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 112  Solved: 28 SubmitStat ...

  9. POJ 2342 &&HDU 1520 Anniversary party 树形DP 水题

    一个公司的职员是分级制度的,所有员工刚好是一个树形结构,现在公司要举办一个聚会,邀请部分职员来参加. 要求: 1.为了聚会有趣,若邀请了一个职员,则该职员的直接上级(即父节点)和直接下级(即儿子节点) ...

随机推荐

  1. JDK源码阅读(1)_简介+ java.io

    1.简介 针对这一个版块,主要做一个java8的源码阅读笔记.会对一些在javaWeb中应用比较广泛的java包进行精读,附上注释.对于容易混淆的知识点给出相应的对比分析. 精读的源码顺序主要如下: ...

  2. Servlet小总结

    Servlet Servlet(服务器端小程序)是使用Java语言编写的服务器端程序,像JSP一样,生成动态的Web页.Servlet主要运行在服务器端,并由服务器调用执行. Servlet处理的基本 ...

  3. C#程序打包安装部署

    今天为大家整理了一些怎样去做程序安装包的具体文档,这些文档并不能确保每个人在做安装包的时候都能正确去生成和运行,但是这些文档的指导作用对于需要的朋友来说还是很有必要的,在实际产品的安装部署过程中可能有 ...

  4. css scroll bug

    滚动区域不能设置overflow var doc = $(document), win = $(window), h = $("#head"), b = $("#body ...

  5. Sql 的 RAISERROR用法

    http://www.yesky.com/imagesnew/software/tsql/ts_ra-rz_5ooi.htm RAISERROR 返回用户定义的错误信息并设系统标志,记录发生错误.通过 ...

  6. jQuery 实现无限任意添加下拉菜单

    新学jQuery还有很多没学,今天做了个下拉菜单,按照自己的思想结合学的基础效果实现一款可以任意添加层数的下拉菜单,如果有什么建议,欢迎指教啦啦啦 我喜欢备注细一些,这样给自己也是一种理解和方便回顾哈 ...

  7. PowerShell 函数

    PowerShell 中函数是一系列 PowerShell 语句的组合.当你通过函数的名称调用函数时,函数中的语句会被顺序的执行,就像在命令行中执行它们一样. 从 hello world 开始 fun ...

  8. iOS获取各种数据方法整理以及IDFA与IDFV使用环境

    iOS获取APP版本号: NSString *AppVersion  =  [[NSBundle mainBundle] objectForInfoDictionaryKey:@"CFBun ...

  9. Nodejs的运行原理-调用篇

    前言 之前做过Nodejs的架构篇, 有很多朋友留言给我,说没看懂里面的例子,这里我会重新梳理一下,再以http server为例,来解析Nodejs从前端到libuv的调用过程. 正文 回忆a. N ...

  10. PyQt4 的部件 -- CheckBox 单选框

    单选框具有两种状态:被选中或未被选中. 当用户选择或者取消选择时,单选框就会发射一个stateChanged()信号 # QCheckBox 单选框 # 本例创建一个用来改变窗口标题的单选框 impo ...