首页 技术 正文
技术 2022年11月15日
0 收藏 705 点赞 3,260 浏览 948 个字

传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=3918

【题解】

每日至少更一题啊qwq凑任务(迷

明显猜个结论:随便搜环就行了

然后搜环姿势错了我也很无奈啊。。。

# include <stdio.h>
# include <string.h>
# include <algorithm>
// # include <bits/stdc++.h>using namespace std;typedef long long ll;
typedef long double ld;
typedef unsigned long long ull;
const int M = + ;
const int mod = 1e9+;# define RG register
# define ST staticint n, m;
int head[M], nxt[M], to[M], tot = ;
inline void add(int u, int v) {
++tot; nxt[tot] = head[u]; head[u] = tot; to[tot] = v;
}
inline void adde(int u, int v) {
add(u, v);
add(v, u);
}bool vis[M];
int Final;
int c[M], cn, p[M];inline void dfs(int x) {
if(p[x] != -) {
printf("%d", x);
for (int i=p[x]+; i<=cn; ++i) {
printf(" %d", c[i]);
p[c[i]] = -;
}
puts("");
cn = p[x];
return;
}
c[++cn] = x;
p[x] = cn;
for (int i=head[x]; i; i=nxt[i]) {
if(vis[i] || vis[i^]) continue;
head[x] = nxt[i];
vis[i] = ;
dfs(to[i]);
if(p[x] == -) break;
}
}int main() {
scanf("%d%d", &n, &m);
for (int i=; i<=m; ++i) {
int u, v; scanf("%d%d", &u, &v);
adde(u, v);
} for (int i=; i<=n; ++i) p[i] = -; for (int i=; i<=tot; i++)
if(!vis[i] && !vis[i^])
dfs(to[i]); return ;
}
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,031
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,520
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,368
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,148
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,781
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,861