JZOJ 1301. treecut
1301. treecut (Standard IO)
Time Limits: 1000 ms Memory Limits: 131072 KB
Description
有一个N个节点的无根树,各节点编号为1..N,现在要求你删除其中的一个点,使分割开的连通块中节点个数都不超过原来的一半多。
Input
第一行:一个整数N (1 <= N <= 10,000)。 后面有N-1行:每行两个整数 X 和 Y,表示一个边连接的两个节点号。
Output
输出所有可能选择的点。如果有多个节点,按编号从小到大输出,每个一行。 如果找不到这样的点,输出一行:”NONE”.
Sample Input
10 
1 2 
2 3 
3 4 
4 5 
6 7 
7 8 
8 9 
9 10 
3 8
Sample Output
3 
8
Data Constraint
Hint
样例说明: 删除3号或8号节点,则分枝最多有5个节点
题解
人为规定1为根 
然后dfs搜索就可以了
每次求出节点i的所有儿子的儿子数 
然后判断是否满足小于等于n/2
代码
#include<cstdio>
#include<algorithm>
#include<vector>
#define N 10001
using namespace std;
vector<long>map[N];
long n;
long lc[N],rb[N],ans[N];
bool b[N];
void build(long now)
{   long i,next;
    b[now]=true;
    for(i=0;i<map[now].size();i++)if(!b[map[now][i]]){
        if(!lc[now])lc[now]=map[now][i];
        else rb[next]=map[now][i];
        next=map[now][i];
        build(next);
    }
}
long dfs(long now)
{   long i,q,num=0;
    bool t=true;
    for(i=lc[now];i;i=rb[i]){
        if((q=dfs(i))-1>=long(double(n)/2+0.9))
            t=false;
        num+=q;
    }
    if(t&&n-(num+1)<=long(double(n)/2+0.9))ans[++ans[0]]=now;
    return num+1;
}
int main()
{   long i,x,y;
    scanf("%ld",&n);
    for(i=1;i<n;i++){
        scanf("%ld%ld",&x,&y);
        map[x].push_back(y);
        map[y].push_back(x);
    }
    build(1);
    dfs(1);
    if(!ans[0])printf("NONE\n");
    else{
        sort(ans+1,ans+ans[0]+1);
        for(i=1;i<=ans[0];i++)
            printf("%ld\n",ans[i]);
    }
    return 0;
}JZOJ 1301. treecut的更多相关文章
- HDOJ 1301
		9852303 2013-12-18 11:47:01 Accepted 1301 0MS 264K 1117 B C++ 泽泽 Jungle Roads Time Limit: 2000/1000 ... 
- hdu 1301 Jungle Roads 最小生成树
		题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1301 The Head Elder of the tropical island of Lagrish ... 
- HDOJ 1301 Jungle Roads
		题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1301 //HDOJ1301 #include<iostream>#include<c ... 
- hihocoder #1301 : 筑地市场  数位dp+二分
		题目链接: http://hihocoder.com/problemset/problem/1301?sid=804672 题解: 二分答案,每次判断用数位dp做. #include<iostr ... 
- bzoj1098 1301
		这两题很类似,都是在补图上搜索 但是由于补图太大我们不能建出来 考虑先从一个点搜,每次搜可以搜的点, 然后维护一个链表,记录当前还没有搜过的点,搜过之后从链表中删除即可 type node=recor ... 
- hdu 1301 Jungle Roads
		http://acm.hdu.edu.cn/showproblem.php?pid=1301 #include <cstdio> #include <cstring> #inc ... 
- Hdu 1301 Jungle Roads (最小生成树)
		地址:http://acm.hdu.edu.cn/showproblem.php?pid=1301 很明显,这是一道“赤裸裸”的最小生成树的问题: 我这里采用了Kruskal算法,当然用Prim算法也 ... 
- (jzoj snow的追寻)线段树维护树的直径
		jzoj snow的追寻 DFS序上搞 合并暴力和,记录最长链和当前最远点,距离跑LCA # include <stdio.h> # include <stdlib.h> # ... 
- [jzoj]3506.【NOIP2013模拟11.4A组】善良的精灵(fairy)(深度优先生成树)
		Link https://jzoj.net/senior/#main/show/3506 Description 从前有一个善良的精灵. 一天,一个年轻人B找到她并请他预言他的未来.这个精灵透过他的水 ... 
随机推荐
- 做成像的你不能不了解的真相7-两分钟测算相机增益(Gain)
			前几期真相文章得到了读者积极的反馈,其中提问最多的就是这个公式: 首先,大家觉得这个公式太有用了.以前只能定性地评价图像质量,现在一下子就能直接算出信噪比,瞬间高大上了许多有木有.然而,杯具的现实是, ... 
- zcat|subprocess.check_all|subprocess.Popen|gzip|readline()
			#!/usr/bin/python from subprocess import check_call import subprocess import gzip ''' $ zcat 160121_ ... 
- vue实现动态绑定class--多个按钮点击一个有一个
			<template> //v-for循环出来多个按钮,便于获取index <span v-for="(item,index) in list" : ... 
- 高性能JAVA开发之内存管理
			这几天在找一个程序的bug,主要是java虚拟机内存溢出的问题,调研了一些java内存管理的资料,现整理如下: 一.JVM中的对象生命周期 对象的生命周期一般分为7个阶段:创建阶段,应用阶段,不可视阶 ... 
- crm项目-权限组件
			############### 表结构分析 ################ """ 表结构设计: 1,四张表 用户表,userinfo,这个表本身不会被创 ... 
- FFT算法的verilog实现
			首先需要明白傅里叶相关的基本知识:还是 借用这位英雄的文章,真心写的让人佩服不已http://blog.jobbole.com/70549/ 然后是卷积的理解http://blog.csdn.net/ ... 
- MOOC(7)- case依赖、读取json配置文件进行多个接口请求-openpyxl读取excel(14)
			从excel中读取数据 # -*- coding: utf-8 -*- # @Time : 2020/2/12 17:23 # @File : do_excel_openpyxl_14.py # @A ... 
- python2查找匹配数据及类型转换
			判断一个字符是否包含在另一个字符串中,如果包含,但是数据类型不同,需要进行数据类型转换 下面这个是针对python2 
- UFT三种录制方式
			1.正常录制(Normal Recording) QTP默认的录制模式,这种录制模式是QTP最突出的特点,是直接对对象的操作,可以说此类模式继承了对象模型的所有优点,能够充分发挥对象库的威力.它通过识 ... 
- OpenCV 腐蚀与膨胀(Eroding and Dilating)
			#include "opencv2/imgproc/imgproc.hpp" #include "opencv2/highgui/highgui.hpp" #i ... 
