UVA11125 - Arrange Some Marbles(dp)
UVA11125 - Arrange Some Marbles(dp)
题目大意:给你n种不同颜色的弹珠。然后给出每种颜色的弹珠的个数,如今要求你将这些弹珠排序,要求同样颜色的部分最多3个。然后同样颜色的弹珠称为一个组。那么每一个相邻的组要求长度不同。颜色也不同,然后首位的两组也要符合要求。
解题思路:这题之前是被n<3000给吓到了,后面dp还那么多状态,感觉复杂度不能过。后面看了题解才发现dp的时候会将全部的情况包含进去,所以仅仅要dp的数组的复杂度够即可了,和n没有关系。由于这题有给弹珠的数目,所以须要记录一下每种颜色的弹珠的剩余数目。那么就是8∗8∗8∗8.(能够用一个8进制的数来取代传4个參数)由于还要求相邻的颜色和长度不同。所以还要3∗4来存放上一次是什么颜色长度是多少。麻烦的是首尾怎么办。枚举出首的组那么相应的尾也就优点理了。所以再开3∗4将第一个的颜色和大小存储进去。这样复杂度就是8∗8∗8∗8∗144。注意:0的时候输出的是1.
为什么和n没有关系呢,由于题目变动的仅仅是颜色的数目和各个颜色的个数,而我们dp的时候是将会出现的四种颜色,会出现的全部个数都包含进去了。
代码:
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
const int maxn = 4500;
const int maxs = 5;
const int maxc = 5;
int N, PS, PC;
int num[maxc];
int f[maxn][maxs][maxc][maxs][maxc];
int dp (int state, int s, int c) {
int& ans = f[state][PS][PC][s][c];
if (ans != -1)
return ans;
if (!state) {
if (PS != s && PC != c)
return ans = 1;
return ans = 0;
}
int tmp[maxc];
int tS = state;
for (int i = N - 1; i >= 0; i--) {
if (tS >= (1<<(3*i))) {
tmp[i] = tS/(1<<(3*i));
tS %= (1<<(3*i));
} else
tmp[i] = 0;
}
ans = 0;
for (int i = 0; i < N; i++) {
if (i == c)
continue;
for (int j = 1; j <= min(3, tmp[i]); j++) {
if (j == s)
continue;
ans += dp(state - (j * (1<<(3*i))), j, i);
}
}
return ans;
}
void solve () {
scanf ("%d", &N);
for (int i = 0; i < N; i++)
scanf ("%d", &num[i]);
int state = 0;
for (int i = 0; i < N; i++)
state += num[i] * (1<<(3*i));
int ans = 0;
if (state) {
for (int c = 0; c < N; c++)
for (int s = 1; s <= min(num[c], 3); s++) {
PS = s;
PC = c;
ans += dp(state - s * (1<<(3*c)), s, c);
}
} else
ans = 1;
printf ("%d\n", ans);
}
int main () {
int T;
scanf ("%d", &T);
memset (f, -1, sizeof(f));
while (T--) {
solve();
}
return 0;
}
UVA11125 - Arrange Some Marbles(dp)的更多相关文章
- LightOJ 1033 Generating Palindromes(dp)
LightOJ 1033 Generating Palindromes(dp) 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid= ...
- lightOJ 1047 Neighbor House (DP)
lightOJ 1047 Neighbor House (DP) 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=87730# ...
- 【POJ 3071】 Football(DP)
[POJ 3071] Football(DP) Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 4350 Accepted ...
- 初探动态规划(DP)
学习qzz的命名,来写一篇关于动态规划(dp)的入门博客. 动态规划应该算是一个入门oier的坑,动态规划的抽象即神奇之处,让很多萌新 萌比. 写这篇博客的目标,就是想要用一些容易理解的方式,讲解入门 ...
- Tour(dp)
Tour(dp) 给定平面上n(n<=1000)个点的坐标(按照x递增的顺序),各点x坐标不同,且均为正整数.请设计一条路线,从最左边的点出发,走到最右边的点后再返回,要求除了最左点和最右点之外 ...
- 2017百度之星资格赛 1003:度度熊与邪恶大魔王(DP)
.navbar-nav > li.active > a { background-image: none; background-color: #058; } .navbar-invers ...
- Leetcode之动态规划(DP)专题-详解983. 最低票价(Minimum Cost For Tickets)
Leetcode之动态规划(DP)专题-983. 最低票价(Minimum Cost For Tickets) 在一个火车旅行很受欢迎的国度,你提前一年计划了一些火车旅行.在接下来的一年里,你要旅行的 ...
- 最长公共子序列长度(dp)
/// 求两个字符串的最大公共子序列长度,最长公共子序列则并不要求连续,但要求前后顺序(dp) #include <bits/stdc++.h> using namespace std; ...
- Leetcode之动态规划(DP)专题-647. 回文子串(Palindromic Substrings)
Leetcode之动态规划(DP)专题-647. 回文子串(Palindromic Substrings) 给定一个字符串,你的任务是计算这个字符串中有多少个回文子串. 具有不同开始位置或结束位置的子 ...
随机推荐
- UIViewAdditions(一个非常方便的工具类用它)
我们在project在,改变或多或少控件的坐标-宽度-高度,然后,经常看到你的self.view.frame.origin.x,self.view.frame.size.width.........相 ...
- Unable to load Virtual engine
相关:GenyMotion自带VirtualBox 解决办法:首先确认genymotion及virtualBox正确安装,然后右键点击启动程序选属性,在兼容性里选以兼容模式运行,同时勾选以管理员身份运 ...
- ThreadLocal可能引起的内存泄露(转)
threadlocal里面使用了一个存在弱引用的map,当释放掉threadlocal的强引用以后,map里面的value却没有被回收.而这块value永远不会被访问到了. 所以存在着内存泄露. 最好 ...
- Codeforces 439C Devu and Partitioning of the Array(模拟)
题目链接:Codeforces 439C Devu and Partitioning of the Array 题目大意:给出n个数,要分成k份,每份有若干个数,可是仅仅须要关注该份的和为奇数还是偶数 ...
- HDU 4081-Parsing URL(水)
Parsing URL Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65768/65768 K (Java/Others) Tota ...
- Android AIDL使用特定的解释
1.什么是aidl:aidl这是 Android Interface definition language缩写,认清,这是android进程间通信接口的叙事语言描述.通过它我们可以定义进程间通信接口 ...
- (大数据工程师学习路径)第二步 Vim编辑器----高级功能入门
一.多文件编辑 1.使用vim编辑多个文件 编辑多个文件有两种形式,一种是在进入vim前使用的参数就是多个文件.另一种就是进入vim后再编辑其他的文件. 同时创建两个新文件并编辑 $ vim 1.tx ...
- 第10章 外观模式(Façade Pattern)
原文 第10章 外观模式(Façade Pattern) 概述: 在软件开发系统中,客户程序经常会与复杂系统的内部子系统之间产生耦合,而导致客户程序随着子系统的变化而变化.那么如何简化客户程序 ...
- 用Maven整合SpringMVC+Spring+Hibernate 框架,实现简单的插入数据库数据功能
一.搭建開始前的准备 1.我用的MyEclipse2014版,大家也能够用IDEA. 2.下载Tomcat(免安装解压包).MySQL(zip包下载地址 免安装解压包,优点就是双击启动,最后我会把ba ...
- java 选择文件夹对话框
java swing 选择文件夹对话框 import java.io.File; import javax.swing.JFileChooser; public class Test2 { publi ...