当前位置: 首页 > news >正文

UVa 599 The Forrest for the Trees

题目描述

题目要求统计给定森林中的树和“橡子”的数量。森林由若干连通分量组成,每个连通分量若是一棵树(无环)则计为树,若只有一个孤立节点(无边)则计为橡子。

输入格式

第一行一个整数nnn,表示测试用例数。每个测试用例包含两部分:

  1. 若干行边,每行格式为(A,B),以一行*结束。
  2. 一行顶点列表,格式为A,B,C,...

输出格式

对于每个测试用例,输出一行There are x tree(s) and y acorn(s).

样例

输入

2 (A,B) (B,C) (B,D) (D,E) (E,F) (B,G) (G,H) (G,I) (J,K) (K,L) (K,M) **** A,B,C,D,E,F,G,H,I,J,K,L,M,N (A,B) (A,C) (C,F) ** A,B,C,D,F

输出

There are 2 tree(s) and 1 acorn(s). There are 1 tree(s) and 1 acorn(s).

题目分析

本题的核心是使用并查集(Union-Find\texttt{Union-Find}Union-Find)统计连通分量,并判断每个分量是否为树。

算法

  • 对于每条边,将两个顶点合并。
  • 统计每个连通分量的顶点数和边数。
  • 若边数 = 顶点数−1- 11,则为树;若顶点数=1= 1=1且边数=0= 0=0,则为橡子。

复杂度分析

顶点数≤26\le 2626,边数有限。

代码实现

// The Forrest for the Trees// UVa ID: 599// Verdict: Accepted// Submission Date: 2016-08-12// UVa Run Time: 0.040s//// 版权所有(C)2016,邱秋。metaphysis # yeah dot net#include<bits/stdc++.h>usingnamespacestd;constintMAXN=26;intparent[MAXN],ranks[MAXN];intfindSet(intx){return(x==parent[x]?x:parent[x]=findSet(parent[x]));}voidunionSet(intx,inty){x=findSet(x);y=findSet(y);if(x==y)return;if(ranks[x]>ranks[y])parent[y]=x;else{parent[x]=y;if(ranks[x]==ranks[y])ranks[y]++;}}intmain(){cin.tie(0);cout.tie(0);ios::sync_with_stdio(false);string line;getline(cin,line);intcases=stoi(line);for(inti=1;i<=cases;i++){memset(ranks,0,sizeof(ranks));memset(parent,-1,sizeof(parent));while(getline(cin,line),line.length()>0&&line.front()!='*'){intstart=-1,end=-1;for(intj=0;j<line.length();j++){if(isalpha(line[j])){if(start==-1)start=line[j]-'A';else{end=line[j]-'A';break;}}}if(parent[start]==-1)parent[start]=start;if(parent[end]==-1)parent[end]=end;unionSet(start,end);}while(getline(cin,line)){if(line.length()==0)continue;for(intj=0;j<line.length();j++)if(isalpha(line[j])){intvertex=line[j]-'A';if(parent[vertex]==-1)parent[vertex]=-2;}break;}inttrees=0,acorns=0;for(intj=0;j<26;j++)if(parent[j]==j)trees++;elseif(parent[j]==-2)acorns++;cout<<"There are "<<trees<<" tree(s) and "<<acorns<<" acorn(s).\n";}return0;}
http://www.cnnetsun.cn/news/3002540.html

相关文章:

  • 登报遗失声明收费标准是什么?登报遗失声明去哪办?流程+费用保姆级指南
  • 智人曾经这样灭绝猛犸象:AI入侵与行业灭绝
  • 如何用3分钟解锁15+加密音乐格式:浏览器中的音乐自由革命
  • 应届生为什么要先学技术再找工作?优选产品结构设计的就业优势
  • NewTab Redirect! 终极指南:5步轻松定制你的Chrome新标签页
  • 淘宝闪购 AI 应用研发二面,我笑了!!!
  • SkillNexus:开源 Skills 全生命周期创造平台
  • 3步快速掌握知网文献批量下载:学术研究效率提升的终极方案
  • 数值半群相对理想的联络理论:主联络与典范联络的构造与应用
  • 【数据分析】自动驾驶车辆控制的优化前馈补偿器的数据驱动方法matlab代码
  • 专业的厨房商用空调哪个公司强
  • 决策树实战指南:从可解释性到业务落地的完整工作流
  • 如何免费获取百度文库等30+平台文档:kill-doc终极指南
  • designmodel-中一维线体-梁单元绘制-和网格划分!!!
  • 放弃解决一类人的痛点,专注用AI解决一个又一个具体的问题,或许会有新的机会
  • 红外与可见光图像融合|主流 SOTA 模型数据集选取及预处理汇总(Part4)
  • MC9S08MP16 SPI模式故障与BDC调试模块实战解析
  • FanControl终极中文设置指南:3分钟让Windows风扇控制彻底汉化
  • 深度学习进阶(十五)通道注意力 SE
  • 在普通CPU上跑通Vicuna大模型的实战指南
  • Java8 到 Java21 核心新特性详解(附实战代码)2026后端面试必备
  • 早期停止聚合:贝叶斯模型选择与泛化误差控制实战
  • Codex CLI 安装与环境配置完整指南
  • 如何用免费工具快速下载哔咔漫画:打造个人离线图书馆的完整指南
  • 如何高效解决Windows热键冲突:Hotkey Detective实用指南
  • C# 与 C 类型对照速查表
  • 中文NLP的语义断层:3步解决全词掩码技术实践
  • 低压电工- 光电传感器(Photoelectric Sensor)
  • 用 Vercel Eve 的 Subagent 和 Skill 搭建 Agent Team
  • 客流增35%驻留延40%:贵州安顺古城美陈设计核心技巧-肆墨设计