一道很好的dfs加储存路径的题目  :路径保存:每次dfs都存i 当大于max时 将临时数组保存到答案数组

并不是当 当前值大于最大值时更新路径

还要加上一个条件:能回去

#include<bits/stdc++.h>
using namespace std;
int n;
int m1[][];
int valu[];
int ans[];int path[];
int maxi,len; void dfs(int stepn,int sum,int cur)
{ for(int i=cur+;i<=n;i++)
{
if(m1[cur][i])
{
path[stepn]=i; if(m1[i][n+])
{ path[stepn+]=;
if(sum+valu[i]>maxi)
{
maxi=sum+valu[i];
len=stepn+;
for(int j=;j<=len;j++)
{
ans[j]=path[j];
} } } dfs(stepn+,sum+valu[i],i);
} } } int main()
{ int cas;scanf("%d",&cas);int case1=;
while(cas--)
{
maxi=; len=;
ans[]=;
memset(m1,,sizeof(m1)); scanf("%d",&n);
for(int i=;i<=n;i++)scanf("%d",&valu[i]); valu[]=valu[+n]=; int q;
scanf("%d",&q);
while(q--)
{
int a,b;
scanf("%d%d",&a,&b);
m1[a][b]=m1[b][a]=; } if(case1!=)
printf("\n");
printf("CASE %d#\n",case1++); dfs(,,); printf("points : %d\n",maxi);
if(len!=)
{
printf("circuit : ");
for(int i=;i<len;i++)
printf("%d->",ans[i]);
printf("%d\n",ans[len]); } } return ;
}

还可以用dp来做

#include <stdio.h>
#include <string.h>
bool link[][];
int intrest[], dp[], last[], path[];
int main()
{
int t, case_num = ;
//freopen("input.txt", "r", stdin);
scanf("%d", &t);
while(t--)
{
int n, m, i, j;
memset(link, , sizeof(link));
memset(dp, , sizeof(dp));
last[] = ; //last记录上一个走的城市的标号,last[1] = 0是为了让追溯到第一个城市之后就不继续追溯了
scanf("%d", &n);
if(case_num != )
printf("\n");
for(i = ; i <= n; i++)
{
scanf("%d", &intrest[i]);
}
intrest[i] = ; //注意i城市有趣度为0!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
scanf("%d", &m);
for(int i = ; i < m; i++)
{
int a, b;
scanf("%d%d", &a, &b);
link[a][b] = link[b][a] = ;
}
for(i = ; i <= n+; i++) //假设目标城市标号为i(注意到达它之前经过的城市的标号都小于它)
{
for(j = ; j < i; j++)
//遍历到达i城市之前所在的城市的标号的所有可能性,
//更新到达i城的时候的有趣度之和为所有情况中最大的
{
if(dp[j]+intrest[i] > dp[i] && link[i][j])
{
dp[i] = dp[j]+intrest[i];
last[i] = j;
}
}
}
j = ;
i = n+;
while(last[i])
{
path[j++] = last[i];
i = last[i];
}
printf("CASE %d#\n", case_num++);
printf("points : %d\n", dp[n+]);
printf("circuit : ");
for(i = j-; i >= ; i--)//注意输出的个数并非为城市数目!!!!!!!!!!!!!
{
printf("%d->", path[i]);
}
printf("1\n");
}
return ;
}

回顾

#include<iostream>
#include<queue>
#include<cstdio>
#include<cstring>
#include<vector>
#include<map>
#include<algorithm>
#include<cmath>
using namespace std; #define N 105
#define inf 0x3f3f3f3f int ans[N];
int path[N];
int n,maxx;
int mp[N][N];
int city[N];
int len; void dfs(int cur,int interest,int num)
{
for(int i=cur+;i<=n;i++)
{
if(mp[cur][i])
{
int t=interest+city[i];
path[num]=i;
if(t>maxx&&mp[i][n+])
{ maxx=t;
for(int i=;i<=num;i++)
ans[i]=path[i];
len=num;
}
dfs(i,t,num+);
}
}
} int main()
{
int cas;cin>>cas;
for(int kase=;kase<=cas;kase++)
{
memset(mp,,sizeof mp);
scanf("%d",&n); for(int i=;i<=n;i++)
scanf("%d",&city[i]);
city[n+]=city[]=; int m,a,b;
cin>>m;
while(m--)
{
scanf("%d%d",&a,&b);
mp[a][b]=mp[b][a]=;
}
path[]=;
maxx=;
dfs(,,); if(kase!=)printf("\n");
printf("CASE %d#\n",kase);
printf("points : %d\ncircuit : ",maxx);
for(int i=;i<=len;i++)
printf("%d->",ans[i]);
printf("%d\n",);
}
}

Free DIY Tour HDU1224的更多相关文章

  1. HDU ACM 1224 Free DIY Tour (SPFA)

    Free DIY Tour Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Tot ...

  2. HDU 1224 Free DIY Tour(spfa求最长路+路径输出)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1224 Free DIY Tour Time Limit: 2000/1000 MS (Java/Oth ...

  3. 动态规划:HDU1224-Free DIY Tour

       Free DIY Tour Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

  4. 【dfs or 最短路】【HDU1224】【Free DIY Tour】

    路径只能由小序号到大序号..(起点可以视为最小的序号和最大的序号) 问怎么走 happy值最大.. DFS N=100 且只能小序号到大序号 显然dfs可以过.. 但是存路径的时候sb了.....应该 ...

  5. F - Free DIY Tour(动态规划,搜索也行)

    这道题可用动态规划也可以用搜索,下面都写一下 Description Weiwei is a software engineer of ShiningSoft. He has just excelle ...

  6. HDU1224-Free DIY Tour(SPFA+路径还原)

    Weiwei is a software engineer of ShiningSoft. He has just excellently fulfilled a software project w ...

  7. HDU 1224 Free DIY Tour

    题意:给出每个城市interesting的值,和城市之间的飞行路线,求一条闭合路线(从原点出发又回到原点) 使得路线上的interesting的值之和最大 因为要输出路径,所以用pre数组来保存前驱 ...

  8. 【HDOJ】1224 Free DIY Tour

    DP. #include <cstdio> #include <cstring> #include <cstdlib> #include <algorithm ...

  9. hdu Free DIY Tour

    http://acm.hdu.edu.cn/showproblem.php?pid=1224 #include <cstdio> #include <cstring> #inc ...

随机推荐

  1. android 加载图片

    package mydemo.mycom.demo2; import android.graphics.Bitmap; import android.graphics.BitmapFactory; i ...

  2. Linux之更改Nginx映射默认根目录

     更改nginx映射默认根目录: 1.打开默认配置文件:sudo  vi /etc/nginx/sites-available/default 2.修改配置:root /var/www/html/xx ...

  3. DjangoAdmin自定义过滤器

    class UserIDFilter(admin.SimpleListFilter): # 自定义用户查询过滤器 title = _('关联用户') parameter_name = 'user_id ...

  4. break case

    #include<stdio.h> main() { ; switch (g){ : : printf("haha"); break; : printf("h ...

  5. adb查看安卓设备系统Android版本

    adb shell getprop "ro.build.version" 结果中如下两项便是版本信息: [ro.build.version.release]: [4.4.4][ro ...

  6. 2017/05/03 java 基础 随笔

    1.硬盘500G 厂商是按照1000计算的 500g=500*1000*1000/1024/1024=465g 2.jdk1.7可以表示二进制了 0b001(b大小写无所谓) 3.进制转换 4.原码, ...

  7. DFP算法(转载)

    转载链接:http://blog.csdn.net/itplus/article/details/21896981 注意:式(2.25)中,蓝色变量之所以是实数可以根据它们的矩阵系数相乘为1*1得到.

  8. AT91RM9200---SMC简介

    1.前言 SMC(Static Memory Controller)Atmel 9200静态存储控制器的简称,它可以产生信号来控制外部静态存储和外设.SMC可通过编程寄存器来进行配置. 它有8路片选和 ...

  9. Linux 查看CPU信息,机器型号,内存等信息

  10. ubuntu数据库迁移

    环境:ubuntu16.04 简介:本教程演示如何从旧数据库服务器服转移到另一个新服务器. 场景:假设你有自己的云服务器安装了WordPress站点,你为了更多的内存和处理能力想升级到新的服务器. 操 ...