HDU 2614 Beat(dfs)
来源:互联网 发布:神雕群芳谱知乐改编 编辑:程序博客网 时间:2024/06/05 05:02
Description
有n个问题,map[i][j]表示解决完i问题后去解决j问题的用时,每次解决一个问题的时间必须是非严格递增的,现在从第0个问题开始解决,第0个问题用时为0,问最多可以解决多少问题
Input
多组输入,每组用例第一行为一整数n表示问题个数,之后一个n*n矩阵map,map[i][j]表示解决完i问题后去解决j问题的用时,以文件尾结束输入
Output
对于每组用例,输出能够解决的最多问题数
Sample Input
3
0 0 0
1 0 1
1 0 0
3
0 2 2
1 0 1
1 1 0
5
0 1 2 3 1
0 0 2 3 1
0 0 0 3 1
0 0 0 0 2
0 0 0 0 0
Sample Output
3
2
4
Solution
dfs,枚举搜索起点,每次往下深搜的条件是满足用时非严格递增,不断更新最大搜索深度即可
Code
#include<cstdio>#include<cstring>#include<algorithm>using namespace std;int map[20][20];bool vis[20];int n,ans;void dfs(int now,int len,int time){ ans=max(ans,len);//不断更新最大搜索深度 for(int i=1;i<n;i++)//枚举下一道题 if(!vis[i]&&map[now][i]>=time)//满足继续做的条件 { vis[i]=true;//标记这个问题表示已经解决 dfs(i,len+1,map[now][i]);//深搜 vis[i]=false;//回溯 } return ; }int main(){ while(scanf("%d",&n)!=EOF) { for(int i=0;i<n;i++) for(int j=0;j<n;j++) scanf("%d",&map[i][j]); memset(vis,false,sizeof(vis));//初始化 vis[0]=true;//从第0个问题开始解决 ans=0;//最大解题数 for(int i=1;i<n;i++)//枚举搜索起点 { vis[i]=true;//标记这个问题表示已经解决 dfs(i,2,map[0][i]);//深搜 vis[i]=false;//回溯 } printf("%d\n",ans); } return 0;}
0 0
- HDU 2614 Beat(dfs)
- HDU 2614 Beat (DFS)
- HDU 2614 Beat(DFS)
- HDU 2614 Beat(dfs)
- hdu 2614 Beat (dfs)
- HDU 2614 Beat (dfs)
- HDU 2614 Beat (DFS)
- HDU 2614 Beat(dfs+回溯)
- 【DFS】 HDU 2614 Beat 水
- hdu 2614 BEAT 回溯的dfs
- HDOJ 题目2614 Beat(DFS)
- hdu(2614) Beat
- hdu 2614 Beat
- HDU 2614 Beat
- hdu 2614 Beat
- HDU 2614 Beat
- hdu 2614 beat
- hdu 2614 Beat
- Android不透明度16进制值
- 背景建模-均值法(Matlab)高斯背景建模(opencv)
- 如何把ppt幻灯片转成pdf文档
- 【java】java各种删除指定文件夹或文件方法详解
- lodash摘要
- HDU 2614 Beat(dfs)
- SylixOS Shell使用
- 迷宫问题——回溯法解
- 回调函数和函数指针
- [软件工程]提前完成任务的风险如何定义
- 【java】for循环语句的3种遍历方法
- "svn检出"has encountered a problem cannot checkout
- 干货分享!不得不看的【7年竞价实战经验总结】
- 【wed】wed网页随机产生验证码图片(版本tomcat-8.0.14)