nssl1149,jzoj5455-拆网线【贪心】

正题

jzoj题目链接:https://jzoj.net/senior/#main/show/5455


题目大意

一棵树中选k个点要求留下最小边使每个点都至少有一个点连接。


解题思路

我们先不考虑树的限制,那么k个点满足要求的话最小边数为(k+1)/2(k+1)/2(k+1)/2,然后我们考虑一颗树上有多少个这样的点对满足。也就是选择最多的边数使得每条边两边的点都不重复。

当然,这样的话每条边选最下面的边是最优的,这时候我们就要知道输入保证了一个点的父亲的编号小与他,所以我们按照这个加边顺序倒着枚举点就保证了每次加他和他父亲是最优的了。

然后如果有还不足的就一点对一边就好了。


code

#include<cstdio>
#include<cstring>
#include<algorithm>
#define N 110000
using namespace std;
int fa[N],t,n,k,x,v[N],ans;
int read(){char c=getchar();int x=0;for(;'0'>c||c>'9';c=getchar());for(;'0'<=c&&c<='9';c=getchar()) x=x*10+(c-'0');return x;
}
int main()
{freopen("init.txt","r",stdin);//freopen("tree.out","w",stdout);scanf("%d",&t);for(int ti=1;ti<=t;ti++){memset(v,0,sizeof(v));scanf("%d%d",&n,&k);ans=0;for(int i=2;i<=n;i++)fa[i]=read();for(int i=n;i>1;i--)if(!v[i]&&!v[fa[i]]) ans++,v[fa[i]]=true;//允许加边if(ans*2<k) ans+=k-ans*2;//点对不足else if(ans*2>k) ans-=(ans*2-k)/2;//点对超过printf("%d\n",ans);}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/323524.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

完成图片拖拽

<html> <head><meta charset"UTF-8"><title>拖拽</title><style type"text/css">#box1{width: 100px;height: 100px;background-color: yellow;position:absolute;}#box2{width: 100px;height: 100px;background-colo…

深入探索 Java 热部署

转载自 深入探索 Java 热部署 简介 在 Java 开发领域&#xff0c;热部署一直是一个难以解决的问题&#xff0c;目前的 Java 虚拟机只能实现方法体的修改热部署&#xff0c;对于整个类的结构修改&#xff0c;仍然需要重启虚拟机&#xff0c;对类重新加载才能完成更新操作。对…

手把手教你使用spring cloud+dotnet core搭建微服务架构:服务治理(-)

背景公司去年开始使用dotnet core开发项目。公司的总体架构采用的是微服务&#xff0c;那时候由于对微服务的理解并不是太深&#xff0c;加上各种组件的不成熟&#xff0c;只是把项目的各个功能通过业务层面拆分&#xff0c;然后通过nginx代理&#xff0c;项目最终上线。但是这…

谈谈那些被面与面的经历(面试杂谈)

大家好&#xff0c;我是雄雄。 前言 每个程序员&#xff0c;都会经历大大小小的面试&#xff0c;当你在一个公司做技术大牛时&#xff0c;你可能充当的是一个面试官的角色&#xff0c;此时由你来面别人&#xff1b;当你要去一个公司做大牛时&#xff0c;此时的你&#xff0c;充…

nssl1150,jzoj5309-密室【分层建图,SPFA】

正题 jzoj题目链接:https://jzoj.net/senior/#main/show/5309 题目大意 有n个点&#xff0c;m条边,k种钥匙。有些点分布了钥匙&#xff0c;有些边需要一些钥匙才可以通过&#xff0c;求1到n的最短路。 解题思路 将图分成2k2k层&#xff0c;每一层用二进制表示不同的钥匙情况…

如何在面试中介绍自己的项目经验

转载自 如何在面试中介绍自己的项目经验 在面试时&#xff0c;经过寒暄后&#xff0c;一般面试官会让介绍项目经验 。常见的问法是&#xff0c;说下你最近的&#xff08;或最拿得出手的&#xff09;一个项目。 根据我们的面试经验&#xff0c;发现有不少候选人对此没准备&am…

Configuration Extensions - 简化配置,让你配置支持变量

在开发“RabbitCloud”项目时&#xff0c;使用配置文件发现会有很多重复值&#xff0c;所以我基于”Microsoft.Extensions.Configuration”写了一个扩展库&#xff0c;来丰富对配置的支持。实际案例——“RabbitCloud”之前&#xff0c;我是这样的因为公司ip和家里机器的ip不一…

如何配置frp到linux服务器和windows本地,服务端支持自启动

大家好&#xff0c;我是雄雄&#xff0c;如果你觉得文章还不错的话&#xff0c;欢迎在文末点赞和评论。 前言 最近这段时间都在开发微信服务&#xff08;公众&#xff09;号相关技术&#xff0c;对于写了好几年的后端程序的我来说&#xff0c;开发小程序和服务号&#xff0c;刚…

插入链接

简单的插入链接&#xff0c;直接提供跳转页面项 <!DOCTYPE html> <html><head><meta charset"utf-8"><title></title></head><body><a href"oneclick.html">点我一下&#xff0c;有惊喜</a>…

ssl提高组周六模拟赛【2018.9.15】

前言 这次那了一个和fuW并列的第一&#xff0c;然而似乎都不是很难。(因为第1题有bug所以满分不了) 成绩 只放Rank 1∼10Rank1∼10RankRankPersonPersonScoreScore112015hjw" role="presentation" style="position: relative;">2015hjw2015hjw19…

java面试线程必备知识点,怼死面试官,从我做起

转载自 java面试线程必备知识点&#xff0c;怼死面试官&#xff0c;从我做起 |--多线程一定好么&#xff1f; cpu密集不好 io密集好 |--如何减少上下文切换&#xff1a; 无锁并发&#xff08;数据id根据Hash分段&#xff09;、CAS、最少线程 |--java线程避免死锁&#xff…

错误代码:88000, 错误信息:without comment privilege hint: [7oJ0533w689] rid: 630432cd-15944cf6-083e04fc

大家好&#xff0c;我是雄雄。 问题复现 这个问题&#xff0c;是我在操作&#xff1a;给微信公众平台上添加图文到草稿箱时&#xff0c;遇到的。 报错信息如下&#xff1a; {"errcode":88000,"errmsg":"without comment privilege hint: [7oJ0533w6…

asp.net core AuthenticationMiddleware 在WebApi中的的使用

在.net framework 4.5架构下使用认证&#xff08;Authentication&#xff09;授权(Authorization)。IIS使用HttpModule进行认证&#xff08;Authentication&#xff09;&#xff0c;我们可以选择自己实现认证方式并在web.config中配置&#xff0c;当然也可以选择IIS默认提供的几…

初衷以及目的

因为我学的是软件工程专业的嘛&#xff0c;当初高考误打误撞选择了这门专业&#xff0c;也算是满意吧&#xff0c;毕竟自己对计算机还是挺感兴趣的。 很早以前我就想把计算机学好&#xff0c;希望用华丽的编程技术去创造有趣的游戏&#xff0c;但一直因为各种因素直到高三我才…

P1032-字串变换【bfs】

正题 评测记录:https://www.luogu.org/recordnew/lists?uid52918&pidP1032 题目大意 给若干个变化规则&#xff0c;表示A中的axa_xax​子串可以变化为bxb_xbx​中的子串&#xff0c;求至少要多少次变化才可以变为B子串。 解题思路 暴力广搜用mapmapmap库判重。 codecod…

WebSocket In ASP.NET Core(二)

Introduce上篇博文中&#xff0c;介绍了WebSocket的基本原理&#xff0c;以及一个简单的Demo用来对其有一个大致的认识。这篇博文讲的是我们平常在网站上可能会经常遇到的——实时聊天&#xff0c;本文就是来讲在.NET-Core使用WebSocket来实现一个“乞丐版”的在线实时聊天Demo…

不支持POST请求方法,支持以下GET、

大家好&#xff0c;我是雄雄。 刚刚在用**FeignClient**注解的时候&#xff0c;报了个错&#xff0c;不支持POST请求方法&#xff0c;支持以下GET、。 字面意思上看&#xff0c;好像是让把请求方式从post改成get. 但是&#xff0c;我检查了下我的代码&#xff0c;get提交方式…

Java面试之数据库面试题

转载自 Java面试之数据库面试题 1、触发器的作用&#xff1f; 触发器是一中特殊的存储过程&#xff0c;主要是通过事件来触发而被执行的。它可以强化约束&#xff0c;来维护数据的完整性和一致性&#xff0c;可以跟踪数据库内的操作从而不允许未经许可的更新和变化。可以联级…

P3701 -「伪模板」主席树【网络流,最大流】

正题 评测记录:https://www.luogu.org/recordnew/lists?uid52918&pidP3701 题目大意 给出若干个人的克制关系 给出两边每个人的种类和血量。当两个人pkpkpk后&#xff0c;双方各−1hp-1hp−1hp&#xff0c;同一边的YYYYYYYYY可以给每个同一方的J1hpJ\ 1hpJ 1hp&#xf…

给数组调换顺序

#include<stdio.h> main(){int i,j,t,a[]{1,2,3,4,5};i0;j4;while(j>i){ta[i];a[i]a[j];a[j]t;i;j--;}for(i0;i<5;i){printf("%d ",a[i]);} }1、注意a【】里面的值&#xff0c;后面有大括号可以不写了&#xff0c;写小了反而错了&#xff0c;如果要写后…