题目链接

题意:给出几个基因片段,要求你将它们排列成一个最短的序列,序列中使用了所有的基因片段,而且不能翻转基因。

分析:先计算出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)相关推荐

  1. 【搜索专题】DFS之连通性模型与搜索顺序

    内部搜索不用(能)回溯,外部搜索才需要(必须)回溯和恢复现场 A.AcWing 1112. 迷宫 内部搜索的一道dfs模板题,别忘了vis #include<cstdio> #includ ...

  2. 最值得一看的几条简单的谷歌 Google 搜索技巧!

    可能你和我一样,几乎每天都必须与搜索引擎打交道,不过很多时候,你辛辛苦苦搜了半天也没找到合适的资料,然而"高手们"上来一眨眼功夫就能命中目标了.这并不是别人运气好,而是搜索引擎其实 ...

  3. Google和Baidu常用的搜索技巧--转

    原文链接:http://mp.weixin.qq.com/s?__biz=MjM5NTY0MTY1OQ==&mid=2654509772&idx=1&sn=754454e374 ...

  4. 实用的 GitHub 仓库搜索技巧

    前言 我们经常在 GitHub 上学习开源项目,但是 GitHub 众多的仓库总是会让我们眼花缭乱,不能在较短的时间里找到自己想要的项目. 这里分享一下我刚学到的 GitHub 仓库搜索技巧,在记录所 ...

  5. 百度超级搜索技巧集锦

    1."开始连接"."正在连接"搜索免费电影 网络上有很多热心人提供免费电影的下载地址.为了表明真实可靠,把下载过程也同时附上.现在最流行的下载工具是flashg ...

  6. github搜索技巧:快速搜到你想要的!

    前言 不得不说 GitHub 简直就是程序猿的福地,聚集了众多大神在上面分享,在这里可以发现无限的优良资源,不管是初学者还是正在进阶中的青铜王者,都可以在上面找到适合自己的好东西,用好 GitHub ...

  7. 案例 github_github 项目搜索技巧-让你更高效精准地搜索项目

    作者:Suwanbin www.cnblogs.com/suwanbin/p/12113751.html github 搜索技巧 参考自 B站 up 主 CodeSheep 的视频[如何高效地在网上找 ...

  8. 成为高效程序员的几大搜索技巧

    对于缺乏编程知识的人来说,完全有可能编写一个网页或小程序.如果在用Google搜索相关示例时幸运的话,可以搜到现成的代码.即使是经验丰富的程序员,通常也会为了节省时间和精力而在网上搜索解决方案. 如果 ...

  9. 如何使用搜索技巧来成为一名高效的程序员

    没有人是完全独立的孤岛,每个人都是整体的一部分.-- 约翰·多恩 对于缺乏编程知识的人来说,完全有可能编写一个网页或小程序.如果在用Google搜索相关示例时幸运的话,可以搜到现成的代码.即使是经验丰 ...

最新文章

  1. ThreadLocal源码分析
  2. mysql-5.5.25_Linux下安装Mysql-5.5.25
  3. SLAM本质剖析-Open3D
  4. page fault in nonpaged area 蓝屏_记一次蓝屏0x00000050
  5. k8s master 节点加入到可以调配node节点中的命令
  6. c++新特性11 (12)weak_ptr类定义
  7. 第5篇K8S创建资源的两种方式
  8. python中以表示语块_scikitlearn:将数据拟合成块与将其全部拟合到on
  9. Win7笔记本查看无线网卡是否“支持的承载网络”的方法
  10. 《JavaScript启示录》——1.7 原始值(或简单值)
  11. 转:百度又开始踢新浪屁股了
  12. windows端口转发(端口映射)示例
  13. Phase2 Day10 Tree3Set
  14. C语言读取文件数据,操作并保存
  15. 广告学毕业论文选题有哪些?
  16. Codeforces Gym 100015A Another Rock-Paper-Scissors Problem 找规律
  17. java调用微软语音库,微软语音识别SDK总结
  18. 基于主定理以及递推树求解递归算法的时间复杂度
  19. 【java】微信支付生成签名的过程
  20. 希腊字母的读法[转]

热门文章

  1. 第三周项目4顺序表应用2 删除元素在[x,y]之间的所有元素
  2. PCA目标函数的推导
  3. cvtColor函数
  4. 【解决方案】npm安装vue超时(ERR! errno ETIMEDOUT)
  5. Hadoop记录-监控几个思路
  6. DevOps安装、部署持续集成
  7. 安装 centos7
  8. 使用js实现放大镜效果
  9. bootstrap中图片的一些小事情
  10. mysqli存储过程