poj 1699 Best Sequence (搜索技巧 剪枝 dfs)
题目链接
题意:给出几个基因片段,要求你将它们排列成一个最短的序列,序列中使用了所有的基因片段,而且不能翻转基因。
分析:先计算出add数组,再dfs枚举。
空间复杂度O(n*n), 最坏时间复杂度 O(n^n),但是剪枝以后很快,因为好多搜不到后面,搜不到第n层。
1 #include <iostream> 2 #include <cstring> 3 #include <cstdlib> 4 #include <cmath> 5 #include <cstdio> 6 #include <vector> 7 #include <algorithm> 8 #define LL long long 9 using namespace std; 10 const int maxn = 20+10; 11 const int INF = 1<<28; 12 int n, len[maxn], add[maxn][maxn], ans; 13 bool vis[maxn]; 14 char s[maxn][maxn]; 15 16 void cal(int a, int b, int lena, int lenb) //add计算串a在串b,前面增加的字符个数。 17 { 18 int i, j, k, f, x; 19 for(i = 0; i < lena; i++) 20 { 21 f = 0; 22 for(j = 0, k = i; j < lenb && k < lena; j++, k++) 23 { 24 if(s[a][k] == s[b][j]) continue; 25 else { f = 1; break; } 26 } 27 if(f == 0) break; 28 } 29 x = lena - i; 30 add[a][b] = lenb - x; 31 if(add[a][b]<0) add[a][b] = 0; 32 } 33 void dfs(int pre, int sum, int lenth) //分别代表之前的串,和串的总数,总串的长度。 34 { 35 if(lenth >= ans) return; 36 if(sum == n) 37 { 38 if(lenth < ans) ans = lenth; 39 return; 40 } 41 for(int i = 0; i < n; i++) 42 { 43 if(!vis[i]) 44 { 45 vis[i] = true; 46 if(add[pre][i]==0) //一定要注意这是存在包含串,如abcdabc 包含 dab 47 //串a包含串b,等价于从a到b的边等于0,那么这时,状态在转移时,在原本 48 //是以串a结尾的状态加入串b,此时目标状态仍然是以串a结尾,这里需要注意。 49 dfs(pre, sum+1, lenth+add[pre][i]); 50 else 51 dfs(i, sum+1, lenth+add[pre][i]); 52 vis[i] = false; 53 } 54 } 55 } 56 int main() 57 { 58 int t, i, j; 59 scanf("%d", &t); 60 while(t--) 61 { 62 ans = INF; 63 memset(add, 0, sizeof(add)); 64 memset(vis, false, sizeof(vis)); 65 scanf("%d", &n); 66 for(i = 0; i < n; i++) 67 { 68 scanf("%s", s[i]); 69 len[i] = strlen(s[i]); 70 } 71 for(i = 0; i < n; i++) 72 for(j = 0; j < n; j++) 73 cal(i, j, len[i], len[j]); 74 for(i = 0; i < n; i++) 75 { 76 vis[i] = true; 77 dfs(i, 1, len[i]); 78 vis[i] = false; 79 } 80 printf("%d\n", ans); 81 } 82 return 0; 83 }
转载于:https://www.cnblogs.com/bfshm/p/3863925.html
poj 1699 Best Sequence (搜索技巧 剪枝 dfs)相关推荐
- 【搜索专题】DFS之连通性模型与搜索顺序
内部搜索不用(能)回溯,外部搜索才需要(必须)回溯和恢复现场 A.AcWing 1112. 迷宫 内部搜索的一道dfs模板题,别忘了vis #include<cstdio> #includ ...
- 最值得一看的几条简单的谷歌 Google 搜索技巧!
可能你和我一样,几乎每天都必须与搜索引擎打交道,不过很多时候,你辛辛苦苦搜了半天也没找到合适的资料,然而"高手们"上来一眨眼功夫就能命中目标了.这并不是别人运气好,而是搜索引擎其实 ...
- Google和Baidu常用的搜索技巧--转
原文链接:http://mp.weixin.qq.com/s?__biz=MjM5NTY0MTY1OQ==&mid=2654509772&idx=1&sn=754454e374 ...
- 实用的 GitHub 仓库搜索技巧
前言 我们经常在 GitHub 上学习开源项目,但是 GitHub 众多的仓库总是会让我们眼花缭乱,不能在较短的时间里找到自己想要的项目. 这里分享一下我刚学到的 GitHub 仓库搜索技巧,在记录所 ...
- 百度超级搜索技巧集锦
1."开始连接"."正在连接"搜索免费电影 网络上有很多热心人提供免费电影的下载地址.为了表明真实可靠,把下载过程也同时附上.现在最流行的下载工具是flashg ...
- github搜索技巧:快速搜到你想要的!
前言 不得不说 GitHub 简直就是程序猿的福地,聚集了众多大神在上面分享,在这里可以发现无限的优良资源,不管是初学者还是正在进阶中的青铜王者,都可以在上面找到适合自己的好东西,用好 GitHub ...
- 案例 github_github 项目搜索技巧-让你更高效精准地搜索项目
作者:Suwanbin www.cnblogs.com/suwanbin/p/12113751.html github 搜索技巧 参考自 B站 up 主 CodeSheep 的视频[如何高效地在网上找 ...
- 成为高效程序员的几大搜索技巧
对于缺乏编程知识的人来说,完全有可能编写一个网页或小程序.如果在用Google搜索相关示例时幸运的话,可以搜到现成的代码.即使是经验丰富的程序员,通常也会为了节省时间和精力而在网上搜索解决方案. 如果 ...
- 如何使用搜索技巧来成为一名高效的程序员
没有人是完全独立的孤岛,每个人都是整体的一部分.-- 约翰·多恩 对于缺乏编程知识的人来说,完全有可能编写一个网页或小程序.如果在用Google搜索相关示例时幸运的话,可以搜到现成的代码.即使是经验丰 ...
最新文章
- ThreadLocal源码分析
- mysql-5.5.25_Linux下安装Mysql-5.5.25
- SLAM本质剖析-Open3D
- page fault in nonpaged area 蓝屏_记一次蓝屏0x00000050
- k8s master 节点加入到可以调配node节点中的命令
- c++新特性11 (12)weak_ptr类定义
- 第5篇K8S创建资源的两种方式
- python中以表示语块_scikitlearn:将数据拟合成块与将其全部拟合到on
- Win7笔记本查看无线网卡是否“支持的承载网络”的方法
- 《JavaScript启示录》——1.7 原始值(或简单值)
- 转:百度又开始踢新浪屁股了
- windows端口转发(端口映射)示例
- Phase2 Day10 Tree3Set
- C语言读取文件数据,操作并保存
- 广告学毕业论文选题有哪些?
- Codeforces Gym 100015A Another Rock-Paper-Scissors Problem 找规律
- java调用微软语音库,微软语音识别SDK总结
- 基于主定理以及递推树求解递归算法的时间复杂度
- 【java】微信支付生成签名的过程
- 希腊字母的读法[转]