CodeForces 508D DFS打印欧拉路径

题意很简单,这是一个欧拉路的题目。

要注意的是,打印欧拉路径的递归方法,之前一直用 bool dfs(int i)  的递归方法,如果遇到死路就返回假,再继续递归,直到找到返回值为真的路径。

但无疑这样数据量一大就会超时。

并且对节点的保存也存在不足。

后来看到别人代码,写的很精简:

尤其要注意其递归方法,把输出字符倒着装进string,然后reverse一下!!!!

还有把两个字符转换成ID的思想!!!!

string ans;

reverse( ans.begin() , ans.end() );

#include<cstdio>
#include<vector>
#include<string>
#include<algorithm>
#define For(i,x,y) for (int i=x;i<y;i++)
#define Pb push_back
using namespace std;
const int N=128*128;
vector<int> V[N];
int In[N],n,x,y,S=-1;
string Ans;
char s[5];
int ID(char a,char b) {return a*128+b;}
void DFS(int x)
{
	while (V[x].size()) {int t=V[x].back();V[x].pop_back();DFS(t);}
	Ans+=x%128;
}

int main()
{
	scanf("%d",&n);
	For(i,0,n)
	{
		scanf("%s",s);
		x=ID(s[0],s[1]),y=ID(s[1],s[2]);
		V[x].Pb(y),In[y]++;
	}
	For(i,0,N) if (abs(int(V[i].size())-In[i])>1) return puts("NO"),0;
	For(i,0,N) if (V[i].size()==In[i]+1) if (~S) return puts("NO"),0;else S=i;
	if (S==-1) For(i,0,N) if (V[i].size()) S=i;
	DFS(S);Ans+=S/128;
	reverse(Ans.begin(),Ans.end());
	if (Ans.length()==n+2) puts("YES"),puts(Ans.c_str());else puts("NO");
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值