最近学校网课跟得紧没时间写知识点,就拿题解凑个数(bushi

而且前两天我打着打着题解电脑就突然死机 幸运的是 我没有保存(微笑)

废话不多说 上题目!

城市攻击
(city)
(256MB,1s)
【问题描述】
出于某些原因,A国将对B国进行攻击。B国有n个城市,有n-1
双向条道路,每条道路连接两个城市,任意两个城市可以通过道路
互相到达,即构成一棵树。由于资金有限,A国只能攻击B国的两个
城市,攻击后这两个城市将会毁灭,与这两个城市连接的道路也随
之消失,A国希望在攻击后能将B国分成尽可能多的连通块,这样有
利于A国的下一步行动,于是他们找到你来完成这个任务。
【输入格式】
输入文件名为city.in
第一行包含一个整数T,表示数据组数。
对于每组数据
第一行包含一个整数n,表示B国城市的数量。
接下来n-1行,每行两个整数x,y,表示有一条道路连接城市x与城市y
【输出格式】
输出文件名为city.out
输出文件包含T个整数,表示对于每组数据,攻击两个城市后最多能
使B国分成多少个连通块
【输入样例】
city.in city.out
2
5
1 2
2 4
3 4
4 5
7
1 2
2 3
1 4
1 5
3 6
3 7
3
5

【数据规模与约定】
对于20%的数据T<=5,1≤n≤100
对于50%的数据T<=5,1≤n≤1000
对于100%的数据T<=10,1≤n≤100000

看到这个题说实话我考试的时候二话不说直接爆搜= =

但后来老师一讲就发现其实有窍门

具体看我的详(la)细(ji)题解:

 //通过画图可以看出我们要通过删除度数最多的城市点来拆分连通块,在枚举过程中发现删除xy会得到d[x]+d[y]-n个连通块
//且两点相连时n为2两点不连时n为1
//max分别列举情况 判断即可
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
using namespace std;
struct node//
{
int y,next;//y代表目标位, next的意义参照day3-例1
}a[];
int first[],len;// first【x】从x出发的第一条边
int d[];//度数
void ins(int x,int y)//边列表
{
a[++len].y=y;
a[len].next=first[x];
first[x]=len;
}
bool is_conected(int x,int y)//判断两点之间有没有联系
{
int k;
for(k=first[x];k;k=a[k].next)
if(a[k].y==y)return ;
return ;
}
int main()
{
freopen("city.in","r",stdin);
freopen("city.out","w",stdout);
int o,n,i,j,k,x,y;
scanf("%d",&o);//数据组数
while(o--)
{
scanf("%d",&n);//B国城市数量
for(i=;i<=n;i++) first[i]=d[i]=;//先全部清空一遍
len=;//清空
for(i=;i<n;i++)
{
scanf("%d%d",&x,&y);
ins(x,y);ins(y,x);//存储他们的边 因为是无向图 所以当做双向用
d[x]++;d[y]++;//x,y的度数分别加1
}
int max_d=,sec_d=;//max代指目前度数最大的点 sec代指度数第二大的点 _d代指这个度数的值
int max_s=,m1,m2;//max_s代表目前最大点的个数 m1记录第一个最大点的编号 m2代表第二个 当这两个点都有存储时代表有两个及以上,如果最大度数的点有三个及以上不用记录 一定有两个最大度数点不相连
int sec_s=;//第二大度数的点的个数
for(i=;i<=n;i++)//记录最大度数的点的个数以及第二大度数的点的个数
{
if(d[i]>max_d)//扫描到的点的度数如果比当前的最大的度数值要大
{
sec_d=max_d;
sec_s=max_s;//当前的“最大”度数变成第二大,更新第二大的度数点的相关数据
max_d=d[i];
max_s=;m1=i;//更新最大度数点 m1更新
}
else if(d[i]==max_d)
{
max_s++;//最大度数的点的个数+1
if(max_s==)m2=i;//m2更新
}
else if(d[i]>sec_d)//更新第二大的度数代表的一系列数据
sec_d=d[i],sec_s=;
else if(d[i]==sec_d)
sec_s++;
}//如果又else 什么都不用做 if(max_s>=){printf("%d\n",*max_d-);continue;}
if(max_s==)
{
if(is_conected(m1,m2))//判断两点是否相连
printf("%d\n",*max_d-);
else printf("%d\n",*max_d-);
continue;
}
//max_s=1;无需判断,直接操作
int s=;
for(k=first[m1];k;k=a[k].next)//扫描从x出发的第一条边开始 意为消除第一个城市然后确定连通块数量
{
y=a[k].y;
if(d[y]==sec_d) s++;//这两步的意思是寻找与x相连的sec,s为计数点
}
if(s==sec_s)//如果与max连接的点的数量与总的点的数量一样
printf("%d\n",max_d+sec_d-);//出推论
else printf("%d\n",max_d+sec_d-);//反之,出推论
}
return ;
}

好了大概就这么多

但是这个题没A,why?

因为!

我不会离散化(哭了)

好了如果你喜欢这篇题解别忘了点赞投币收藏……

诶?好像跑题了= =

集训模拟赛-1-T1的更多相关文章

  1. 冲刺$\mathfrak{CSP-S}$集训模拟赛总结

    开坑.手懒并不想继续一场考试一篇文. 既没必要也没时间侧边栏的最新随笔题解反思相间也丑 而且最近越来越懒了竟然都不写题解了……开坑也是为了督促自己写题解. 并不想长篇大论.简要题解也得写啊QAQ. 目 ...

  2. 10-18 noip提高组模拟赛(codecomb)T1倍增[未填]

    T1只想到了找环,> <倍增的思想没有学过,所以看题解看得雨里雾里的(最近真的打算学一下! 题目出的挺好的,觉得noip极有可能出现T1T2T3,所以在此mark 刚开始T1以为是模拟,还 ...

  3. 2017.9.23 NOIP2017 金秋杯系列模拟赛 day1 T1

    回形遍历( calc .cpp/c/pas) 时间限制:1s内存 限制: 256MB [问题 描 述] 给出一个 n*m 的棋盘,按如下方式遍历,请问(x,y)往后 z 步走到的是哪个格子. [输入] ...

  4. 模拟赛DAY1 T1大美江湖

    这就是一个模拟题,注意1234分别对应左右上下横坐标和纵坐标的判断就好了 题解: 需要注意的是,向上取整ceil函数是对于一个double值返回一个double值,也就是说在ceil里面的类型一定要是 ...

  5. 6.30集训模拟赛4(炸裂的一天qwq)

    T1浇水: 题目描述 在一条长n米,宽m米米的长方形草地上放置着k个喷水装置.假设长方形草地的坐标范围为[ 0 , 0 ] ~ [ n , m ],那么第 i 个喷水装置的位置为(ai,m/2),也就 ...

  6. 6.29模拟赛 (T1:李时珍的皮肤衣 T2:马大嘴的废话 T3:SSY的队列 T4:清理牛棚);

    啊,又是考炸的一天,成功的退步了三名,啊,成共的看错了T1  的题意 ,水了80分. 第十五名就是我,额,已经有点倒数的感觉了,并且一道题都没AC  我太难了. 好了,废话不多说了,下面正式提接: 这 ...

  7. 模拟赛18 T1 施工 题解

    前言: 真的是不容易啊.这个题在考场上想到了最关键的性质,但是没写出来. 后来写出来,一直调,小错不断. 没想到改的最后一个错误是两个int 乘起来爆了int 其实最后我还是觉得复杂度很假.\(n^2 ...

  8. 洛谷noip 模拟赛 day1 T1

    T7925 剪纸 题目描述 小芳有一张nnn*mmm的长方形纸片.每次小芳将会从这个纸片里面剪去一个最大的正方形纸片,直到全部剪完(剩下一个正方形)为止. 小芳总共能得到多少片正方形纸片? 输入输出格 ...

  9. 「2018-12-02模拟赛」T1 最短路 解题报告

    1.最短路(short.pas/cpp/in/out) 问题描述: 小 C 终于被小 X 感动了,于是决定与他看电影,然而小 X 距离电影院非常远,现在假设 每条道路需要花费小 X 的时间为 1,由于 ...

  10. 集训模拟赛-1-T2

    好了不要在铺垫了直接整吧就 题目拿来!!!!!!! 倒水 (water) (256MB,1s) [问题描述] 你有一个水桶(记为 0),两个杯子(记为 1,2).水桶中的水量无限,容量也无限.1 号杯 ...

随机推荐

  1. 从零开始实现放置游戏(十三)——实现战斗挂机(4)添加websocket组件

    前两张,我们已经实现了登陆界面和游戏的主界面.不过游戏主界面的数据都是在前端写死的文本,本章我们给game模块添加websocket组件,实现前后端通信,这样,前端的数据就可以从后端动态获取到了. 一 ...

  2. rdd简单操作

    1.原始数据 Key value Transformations(example: ((1, 2), (3, 4), (3, 6)))  2. flatMap测试示例 object FlatMapTr ...

  3. lr具体使用步骤概述

    lr具体使用 1 无工具情况下的性能测试 2性能测试工具LoadRunner的工作原理 3 VuGen应用介绍 4 协议的类型及选择方法 5 脚本的创建过程 6 脚本的参数化 7 调试技术 8 Con ...

  4. 2019-08-01【机器学习】有监督学习之分类 KNN,决策树,Nbayes算法实例 (人体运动状态信息评级)

    样本: 使用的算法: 代码: import numpy as np import pandas as pd import datetime from sklearn.impute import Sim ...

  5. 提升效率必备!8个超好用的Python内置函数

    文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 作者: 吃着不想停 PS:如有需要Python学习资料的小伙伴可以加点击下方链接自 ...

  6. Roles on a Machine Learning Project (机器学习项目中的角色)

    原文 :https://medium.com/machine-learning-in-practice/roles-on-a-machine-learning-project-216903a6dc12 ...

  7. Ubuntu安装Elasticsearch6.3

    本文使用的 Ubuntu 版本信息: Distributor ID: Ubuntu Description: Ubuntu LTS Release: 16.04 Codename: xenial 1. ...

  8. 微信小程序基本知识

    逻辑实现 1 使用动态数据展示列表(可以考虑使用wx:for属性配合动态数组渲染全部列表项,以减少WXML页面的代码量) eg:  <view class='listGroup' wx:for= ...

  9. jQuery(*****)

    参考1 参考2 1. jQuery 1. 选择器 $("") 1. 基本选择器 1. ID --> $("#d1") 2. 标签名 --> $(&q ...

  10. tp5--路由的使用方法(深入)

    懒得写注释,直接上代码 配置文件Route: <?php use think\Route; //tp5路由测试 //动态注册 //Route::rule('路由表达式','路由地址','请求类型 ...