UVA 10651 Pebble Solitaire 状态压缩dp
一开始还在纠结怎么表示一个状态,毕竟是一个串。后来搜了一下题解发现了这里用一个整数的前12位表示转态就好了 ,1~o,0~'-',每个状态用一个数来表示,然后dp写起来就比较方便了。
代码:
- #include <iostream>
- #include <sstream>
- #include <cstdio>
- #include <climits>
- #include <cstring>
- #include <cstdlib>
- #include <string>
- #include <cmath>
- #include <vector>
- #include <queue>
- #include <algorithm>
- #define esp 1e-6
- #define pb push_back
- #define in freopen("in.txt", "r", stdin);
- #define out freopen("out.txt", "w", stdout);
- #define print(a) printf("%d\n",(a));
- #define bug puts("********))))))");
- #define Rep(i, c) for(__typeof(c.end()) i = c.begin(); i != c.end(); i++)
- #define inf 0x0f0f0f0f
- using namespace std;
- typedef long long LL;
- typedef vector<int> VI;
- typedef pair<int, int> pii;
- typedef vector<pii,int> VII;
- typedef vector<int>:: iterator IT;
- #define N 50000
- int dp[N];
- int ans;
- void f(int x)
- {
- if(dp[x])
- return ;
- int num = ;
- for(int i = ; i < ; i++)
- if(x&(<<i))
- num++;
- ans = min(ans, num);
- dp[x] = ;
- for(int i = ; i <= ; i++)
- if(((x&(<<i)) && (x&(<<(i+))) && !(x&(<<(i+))))
- ||(!(x&(<<i)) && (x&(<<(i+))) && (x&(<<(i+)))))
- f(x^(<<(i+))^(<<i)^(<<(i+)));
- }
- int main(void)
- {
- char s[];
- int T, t;
- for(t = scanf("%d", &T), gets(s); t <= T; t++)
- {
- memset(dp, , sizeof(dp));
- gets(s);
- int n = ;
- ans = ;
- for(int i = ; i < ; i++)
- if(s[i] - '-')
- n ^= (<<i);
- f(n);
- printf("%d\n", ans);
- }
- return ;
- }
或者可以用map+string的方法,一直都没怎么学过STL,看了http://www.myexception.cn/ai/1243266.html 这里的方法表示又涨了不少知识,拿来重新写了一遍(其实还是“剽窃”,没办法先当一个"搬运工”吧)。
- #include <iostream>
- #include <sstream>
- #include <cstdio>
- #include <climits>
- #include <cstring>
- #include <cstdlib>
- #include <string>
- #include <cmath>
- #include <stack>
- #include <map>
- #include <vector>
- #include <queue>
- #include <algorithm>
- #define esp 1e-6
- #define pb push_back
- #define in freopen("in.txt", "r", stdin);
- #define out freopen("out.txt", "w", stdout);
- #define print(a) printf("%d\n",(a));
- #define bug puts("********))))))");
- #define Rep(i, c) for(__typeof(c.end()) i = c.begin(); i != c.end(); i++)
- #define inf 0x0f0f0f0f
- using namespace std;
- typedef long long LL;
- typedef vector<int> VI;
- typedef pair<int, int> pii;
- typedef vector<pii,int> VII;
- typedef vector<int>:: iterator IT;
- map<string, bool> my;
- int ans;
- void dfs(string cur)
- {
- if(my.find(cur) != my.end())
- return;
- int len = cur.size(), num = ;
- for(int i = ; i < len; i++)
- if(cur[i] == 'o')
- num++;
- ans = min(ans, num);
- my[cur] = true;
- for(int i = ; i <= ; i++)
- {
- if(cur.substr(i, ) == "-oo")
- {
- string temp = cur;
- temp.replace(i, , "o--");
- dfs(temp);
- }
- if(cur.substr(i, ) == "oo-")
- {
- string temp = cur;
- temp.replace(i, , "--o");
- dfs(temp);
- }
- }
- }
- int main(void)
- {
- int T;
- string s;
- for(int t = scanf("%d", &T); t <= T; t++)
- {
- cin>>s;
- my.clear();
- ans = ;
- dfs(s);
- printf("%d\n", ans);
- }
- return ;
- }
UVA 10651 Pebble Solitaire 状态压缩dp的更多相关文章
- uva 10651 - Pebble Solitaire(记忆化搜索)
题目链接:10651 - Pebble Solitaire 题目大意:给出一个12格的棋盘,‘o'代表摆放棋子,’-‘代表没有棋子, 当满足’-oo'时, 最右边的棋子可以跳到最左边的位子,而中间的棋 ...
- UVa 10651 Pebble Solitaire(DP 记忆化搜索)
Pebble Solitaire Pebble solitaire is an interesting game. This is a game where you are given a board ...
- UVA 10651 Pebble Solitaire(bfs + 哈希判重(记忆化搜索?))
Problem A Pebble Solitaire Input: standard input Output: standard output Time Limit: 1 second Pebble ...
- UVA 11825 - Hackers' Crackdown 状态压缩 dp 枚举子集
UVA 11825 - Hackers' Crackdown 状态压缩 dp 枚举子集 ACM 题目地址:option=com_onlinejudge&Itemid=8&page=sh ...
- hoj2662 状态压缩dp
Pieces Assignment My Tags (Edit) Source : zhouguyue Time limit : 1 sec Memory limit : 64 M S ...
- POJ 3254 Corn Fields(状态压缩DP)
Corn Fields Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 4739 Accepted: 2506 Descr ...
- [知识点]状态压缩DP
// 此博文为迁移而来,写于2015年7月15日,不代表本人现在的观点与看法.原始地址:http://blog.sina.com.cn/s/blog_6022c4720102w6jf.html 1.前 ...
- HDU-4529 郑厂长系列故事——N骑士问题 状态压缩DP
题意:给定一个合法的八皇后棋盘,现在给定1-10个骑士,问这些骑士不能够相互攻击的拜访方式有多少种. 分析:一开始想着搜索写,发现该题和八皇后不同,八皇后每一行只能够摆放一个棋子,因此搜索收敛的很快, ...
- DP大作战—状态压缩dp
题目描述 阿姆斯特朗回旋加速式阿姆斯特朗炮是一种非常厉害的武器,这种武器可以毁灭自身同行同列两个单位范围内的所有其他单位(其实就是十字型),听起来比红警里面的法国巨炮可是厉害多了.现在,零崎要在地图上 ...
随机推荐
- OC1_类与对象
// // main.m // OC1_类与对象 // // Created by zhangxueming on 15/6/9. // Copyright (c) 2015年 zhangxuemin ...
- Java JDK1.5、1.6、1.7新特性整理(转)
原文链接:http://www.cnblogs.com/tony-yang-flutter/p/3503935.html 一.Java JDK1.5的新特性 1.泛型: List<String& ...
- OpenJudge/Poj 2001 Shortest Prefixes
1.链接地址: http://bailian.openjudge.cn/practice/2001 http://poj.org/problem?id=2001 2.题目: Shortest Pref ...
- mysql大数据高并发处理
一.数据库结构的设计 如果不能设计一个合理的数据库模型,不仅会增加客户端和服务器段程序的编程和维护的难度,而且将会影响系统实际运行的性能.所以,在一个系统开始实施之前,完备的数据库模型的设计是必须的. ...
- plsql通过instantclient连接oracle数据库报连接超时
配置:数据库oracle10.2;服务器操作系统centos5.5:客户机操作系统win7 32位:plsql版本10.0.5 配置前提必须关闭客户机与服务器操作系统的防火墙,否则会出现“连接超时”的 ...
- javascript中的sort()方法
现在在学习javascript中,发现sort()函数是有点奇怪的东西(可能是本人水平的问题-_-!),于是就在这里记录一下自己找到的东西吧.sort()这个方法的参数很奇怪,必须是函数,但也是可选参 ...
- 少年Vince之遐想
本文999纯水贴,然转载仍需注明: 转载至http://www.cnblogs.com/VinceYang1994/ 昨天去姑姑家拜年,表哥房间的角落里有一架缠有蜘蛛网的遥控直升飞机. 打开飞机及遥控 ...
- win7下 mysql主从配置实现
win7下学习 mysql主从复制 一.环境: 主服务器(master):192.168.1.23 mysql版本:5.5 从服务器(slave):192.168.1.24 mysql版本:5.5 ...
- C#对word、excel、pdf等格式文件的操作总结
一.word 这是我以前工作时写过的一个业务逻辑处理类,里面有不少文件操作的方法,这里主要关注一下C#对word的操作.里面的方法可以直接拿出来用,主要是通过word的dot模版来进行创建word.替 ...
- Your branch and 'origin/master' have diverged
git fetch origin git reset --hard origin/master