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

洛谷 P11242 碧树 C语言

题目:
P11242 碧树 - 洛谷 | 计算机科学教育新生态

题目背景

English statement. You must submit your code at the Chinese version of the statement.

小 T 不知道交流是什么。

是为了弄懂一串奇怪的符号,然后再把它放入他人的大脑吗?

是为了得到一些抽象的知识,然后再用它打破自己的习惯吗?

为了交流,小 T 最终决定接通了 220V 的电压。

题目描述

t1k1x1ww。

小 T 注视着这一串自己不能理解的符号,决定先和你交流一个 OI 题目。

小 T 有一棵有根树,它共有 k 个叶子结点,同时他还告诉了你,其叶子结点的深度分别为 a1…ak。请你帮他计算,这棵树最少包含多少个结点。小 T 保证存在至少一棵这样的树。

如果您不熟悉题面中的若干定义,我们乐意提醒您:

  • 图上的 简单路径 指一条经过顶点不重复、经过边不重复的路径。
  • 一棵  是一张联通,且任意两点之间有且仅有一条简单路径的图。在一棵树里,我们会选择一个节点为根结点。
  • 树上的 叶子结点 为不是根结点,且度数为 1 的结点。
  • 树上一个节点的 深度 是该结点到根结点的简单路径上结点的个数。

输入格式

第一行一个整数 k。

接下来一行 k 个整数,描述 a1…ak。

输出格式

仅一行一个整数,表示答案。

输入输出样例

输入 #1复制

4
2 3 4 5

输出 #1复制

8

输入 #2复制

7
6 6 7 8 4 2 4

输出 #2复制

14

说明/提示

样例解释

  • 对于第一组数据,下面是一棵可能的树:

其大小为 8,其中叶子 3,5,6,8 的深度分别为 2,3,4,5。容易证明没有大小 ≤7 的树符合题意。

数据规模与约定

本题采用捆绑测试和子任务依赖。

  • Subtask 0(0 pts):样例。
  • Subtask 1(30 pts):k=2。
  • Subtask 2(30 pts):a1=a2=⋯=ak。
  • Subtask 3(40 pts):无特殊限制。依赖于子任务 0∼2。

对于所有数据,保证 1≤k≤105,2≤ai≤105,且保证存在至少一棵这样的树。

思路:

我们可以简单的创造一组数据,画出它的图,我们会发现其最深节点的深度不应当超过要求子叶节点中的最深深度。所以最大深度就是最少节点树的高度,假设有n个深度的叶子结点,当最大深度为m的时候,我们已经确认个一个叶子节点在m层,剩下还有n-1个叶子节点。所以树的叶子结点就是m+n-1。

代码如下:

#include<iostream>
using namespace std;
const int N = 1e5+5;
int n;
int num[N];
int maxh = -1e6;
int main()
{
	cin >> n;
	for(int i = 1 ; i <= n ; i++)
	{
		int t;
		cin >> t;
		if(maxh < t)
		maxh = t;
	}
	cout << maxh + n - 1;
	return 0;
}


http://www.kler.cn/a/451822.html

相关文章:

  • Anton和Danik的棋局对决
  • 以太网通信--读取物理层PHY芯片的状态
  • Mysql InnoDB存储引擎中聚簇索引和非聚簇索引的区别
  • openjdk17 从C++视角看 String的intern的jni方法JVM_InternString方法被gcc编译器连接
  • 学习threejs,THREE.PlaneGeometry 二维平面几何体
  • ArcGIS Pro 3.4新功能3:空间统计新特性,基于森林和增强分类与回归,过滤空间自相关
  • openGauss系列_Centos 7.6 使用 PTK v0.5 安装部署 MogDB v3.0.3 一主两备级联集群
  • YOLOv9-0.1部分代码阅读笔记-plots.py
  • P7——pytorch马铃薯病害识别
  • 使用envoyfilter添加请求头
  • windows nacos安装配置
  • 反应力场的生成物、反应路径分析方法
  • unity弹出新的类似独立场景窗口独立运行一般怎么实现?
  • 【文档搜索引擎】搜索模块的完整实现
  • docker 部署HivisionIDPhotos实现证件照制作
  • springboot/ssm太原学院商铺管理系统Java代码编写web在线购物商城
  • dolphinscheduler服务RPC负载均衡源码解析(二)基于多种不同算法的负载均衡策略实现源码解析
  • 一文掌握如何编写可重复执行的SQL
  • Day55 图论part05
  • 【uniapp】支付宝付款成功后怎么调回自定义页面
  • 51c大模型~合集96
  • vue2版本elementUI的clearable属性和DateTimePicker 下拉框的清空功能冲突
  • MFC/C++学习系列之简单记录1——错误解决与Dialog移植
  • 【hackmymv】emma靶机wp
  • 如何在Facebook发布Reels?简单易懂的操作指南
  • openjdk17 中 klass 数组 在元空间内存分配