题意: 给两行字符串,第一行为一组变量,第二行时一组约束(每个约束包含两个变量,x y 表示 x <y)。输出满足约束的所有字符串序列。

思路:拓扑排序 + 深度优先搜索(DFS算法)

课本代码:

#include<iostream>
#include<cstring>
#include<string>
using namespace std; int n;
int pre[300]; // 存字母入度// 把小写字母的ascii码都包括在内
bool has[300];//节点标志 // 把小写字母的ascii码都包括在内
string var,v;
void dfs(int dep,string res){
if(dep==n+1){ //第n+1个字母不用找(即找完n个字母时结束)
cout<<res<<endl;
return ;
}
for(int i='a';i<='z';i++)//按字典顺序遍历查找入度为0的节点,释放该节点
if(has[i] &&pre[i]==0){
has[i]=false;//删除点
int k;
for(k=0;k<v.length();k+=4)//删除该节点的所有出边
if(v[k]==i) --pre[v[k+2]];
dfs(dep+1,res+char(i));
for(k=0;k<v.length();k+=4)//恢复被删边
if(v[k]==i) ++pre[v[k+2]];
has[i]=true;//恢复点
}
} int main()
{
while(getline(cin,var) &&getline(cin,v))
{
memset(pre,0,sizeof(pre));//初始化节点标志
memset(has,0,sizeof(has));//初始化节点入度
int i;
for(i=0;i<var.length();i+=2)//初始节点标志
has[var[i]]=true;
n=var.length()/2 +1;
for(i=0;i<v.length();i+=4)//统计节点入度
++pre[v[i+2]];
dfs(1,"");
cout<<endl;
}
}

最新文章

  1. ASP.NET MVC中ViewData、ViewBag和TempData
  2. OO之美
  3. 线程高级应用-心得4-java5线程并发库介绍,及新技术案例分析
  4. goldengate的HANDLECOLLISIONS参数
  5. delphi TPopupMenu.Popup
  6. linux-redhat5找回root密码
  7. 如何安装SQL Server 2008数据库(带完整图解)
  8. Android应用程序所包含的四种组件和DDMS
  9. VS2008让自己掌控的定义编译项目后,自己主动添加到工具箱
  10. VS2010暂停编译界面
  11. MySQL 详细学习笔记 转
  12. Maven 错误 :The POM for com.xxx:jar:0.0.1-SNAPSHOT is invalid, transitive dependencies (if any) will not be available
  13. CF3A Shortest path of the king
  14. jdk8中奖Date转换为String格式的方法
  15. 关于nagios系统下使用shell脚本自定义监控插件的编写
  16. C#创建数字证书并导出为pfx,并使用pfx进行非对称加解密
  17. C# 4.0中的动态类型和动态编程
  18. 洛谷P2151 [SDOI2009] HH去散步 [矩阵加速]
  19. elixir mix开发入门
  20. 学习笔记之Struts2—浅析接收参数

热门文章

  1. eclipse +cygwin+C++
  2. PHP自动加载功能原理解析
  3. GUN C中的错误报告
  4. VS2010 fatal error LNK1123: 转换到 COFF 期间失败: 文件无效或损坏
  5. nginx访问日志中的时间格式修改
  6. 算法调参 weight_ratio, weight_seqratio
  7. spider_action
  8. Java基础 - 变量转换
  9. JavaScript点击事件-一个按钮触发另一个按钮
  10. Django 动态导入配置文件的类