尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

CF2112D

CF2112D
📅 发布时间:2026/6/20 6:56:51

注意到一条边无论方向如何,都能使两端的某一个点到达另一个点,即至少有 \(n-1\) 对。如果只需要 \(n-1\) 对,那么只需要在每一条链上相邻的边方向相反即可。对于剩下的一对,我们可以找到一个度数为 \(2\) 的点,并把连接的两条边由反向改为同向,那么附近的三个点产生的对数由 \(2\) 变成了 \(3\),达到要求(如果度数不为 \(2\),那么增加的对数一定不止 \(1\),不能达到要求)。如果找不到则无解。时间复杂度 \(O(\sum n)\)。

#include<iostream>
#include<cstdio>
#include<vector>
#define N 200010
using namespace std;
vector<int> G[N];
int n,rt;
void dfs(int u,int fa,int op){for(auto v:G[u]){if(v==fa)continue;if(op)cout<<u<<' '<<v<<'\n';else cout<<v<<' '<<u<<'\n';dfs(v,u,op^1);}return;
}
void solve(){int u,v;rt=0;cin>>n;for(int i=1;i<=n;i++)G[i].clear();for(int i=1;i<n;i++){cin>>u>>v;G[u].push_back(v);G[v].push_back(u);}for(int i=1;i<=n;i++)if(G[i].size()==2){rt=i;break;}if(!rt){cout<<"NO\n";return;}cout<<"YES\n";cout<<G[rt][0]<<' '<<rt<<'\n';cout<<rt<<' '<<G[rt][1]<<'\n';dfs(G[rt][0],rt,1);dfs(G[rt][1],rt,0);
}
int main(){int T;cin>>T;while(T--)solve();return 0;
}
我们会走到一起的。

相关新闻

  • CF342C
  • LG9648
  • CF2111C

最新新闻

  • 软件测试基础:黑盒、白盒、灰盒测试
  • 2026年工业工厂吸尘器Top3:Shiwosi史沃斯凭什么第一? - 工业清洁测评社
  • 多智能体系统中的向量化声誉传播机制TrustFlow解析
  • Qwen3vl多模态后训练实战:LLamaFactory深度适配指南
  • 国产MLU算网+LLaMA-Factory:零代码微调百余大模型实战指南
  • 猫抓插件:3步搞定浏览器资源嗅探的终极指南

日新闻

  • 信任的进化:技术实现详解——如何用JavaScript构建博弈论模拟器
  • Terrakube自定义工作流:如何集成OPA、Infracost等工具扩展IaC能力
  • grunt-concurrent快速入门:5分钟学会并行运行Grunt任务

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号