2023天梯赛补题

news/2024/4/20 13:10:53/文章来源:https://blog.csdn.net/WQhuanm/article/details/130360995

题目详情 - L2-047 锦标赛 (pintia.cn)

思路:

  1. 这是一棵倒着的树,我们每次匹配时,必须当前的值大于左儿子或者右儿子的最大值,否则无答案。
  2. 因为我们需要存储哪个位置还没放人,发现当前位置左儿子与右儿子都是有且仅有一个位置为空(供当前位置放一个,还有当前位置的父亲(祖先)放一个)
  3. 所以我们填写a[i][j]时,可以记录a[i][j]这个包含的区间的空位坐标。即如果你继承左儿子,那么id[i][j]记录右儿子那个空位
  4. 匹配后,我们要更新a[i][j]的值,即为max(a[i][j],max[左儿子],max[右儿子]),假如a[i][j]打败了左儿子,那么a[i][j]>max[左儿子],那么后面祖先继承a[i][j]包含的空位,首先能打败a[i][j],然后他是继承a[i][j]右儿子空位,所以还要能打败右儿子
#include <bits/stdc++.h>
using namespace std;
#define ll               long long
#define endl             "\n"
const int N = 2e5 + 10;
int a[20][N],id[20][N],ans[N];
void mysolve()
{int k;cin>>k;bool flag=1;for(int i=1; i<=k; ++i)for(int j=1; j<=(1<<(k-i)); ++j){cin>>a[i][j];if(i==1)ans[2*j-1]=a[i][j],id[i][j]=2*j;else{if(a[i][j]<a[i-1][j*2-1]&&a[i][j]<a[i-1][j*2])flag=0;else{if(a[i][j]>=a[i-1][j*2-1])ans[id[i-1][2*j-1]]=a[i][j],id[i][j]=id[i-1][j*2];else ans[id[i-1][2*j]]=a[i][j],id[i][j]=id[i-1][j*2-1];}a[i][j]=max({a[i][j],a[i-1][2*j-1],a[i-1][2*j]});}}int maxn;cin>>maxn;if(maxn<a[k][1])flag=0;else ans[id[k][1]]=maxn;if(!flag)cout<<"No Solution"<<endl;else{for(int i=1; i<=(1<<k); ++i){if(i>1)cout<<" ";cout<<ans[i];}}}int32_t main()
{std::ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);ll t=1;//cin >> t;while (t--){mysolve();}system("pause");return 0;
}

题目详情 - L3-035 完美树 (pintia.cn)

思路:树形dp

  1. 显然是一个值域为3的树形dp。设dp[i][0]表示子树两种色一样多,dp[i][1]表示白色比黑色多1,dp[i][2]表示黑色比白色多1。cnt[i]表示i子树有奇数/偶数个点
  2. 当节点u继承他的儿子们v时
    1. 如果cnt[v]为偶数,显然,只有dp[v][0]有意义,直接继承即可
    2. 如果cnt[v]为奇数,我们需要讨论,总之先计入cnt[u](当前表示有多少个奇数点的儿子的个数),设mid=cnt[u]/2
      1. 如果cnt[u]为奇数,即u子树一个有偶数个点,那么只有dp[u][0]有意义,可以有取mid*dp[v][1]+(cnt[u]-mid)*dp[v][2]+c[u]=0,或者(cnt[u]-mid)*dp[v][1]+mid*dp[v][2]+c[u]=1。取最小
      2. 如果cnt[u]为偶数,即u子树有奇数个点,那么可以更新dp[u][1]或者dp[u][2]。如对于dp[u][1],那么可以取mid*dp[v][1]+mid*dp[v][2]+c[u]=0,或者(mid+1)*dp[v][1]+(mid-1)*dp[v][2]+c[u]=1。dp[u][2]同理。
      3. 而对于怎么取mid个dp[v][1],怎么取剩下的dp[v][2]呢,我们可以先全部取dp[v][1],然后开数组存入dp[v][2]-dp[v][1],之后排序,需要一个dp[v][2],就从数组中取一个,这样就是最优。
#include <bits/stdc++.h>
using namespace std;
#define ll               long long
#define endl             "\n"
const int N = 2e5 + 10;
int cnt[N],dp[N][3],p[N],in[N];
vector<int>edge[N];
bool c[N];
void dfs(int u)
{vector<int>q;int sum=0;for(auto v:edge[u]){dfs(v);if(cnt[v]&1){cnt[u]++;q.push_back(dp[v][2]-dp[v][1]),sum+=dp[v][1];//先全部加dp[v][1],后面需要dp[v][2],取q数组即可}else sum+=dp[v][0];//为0直接累加}sort(q.begin(),q.end());int mid=(int)q.size()/2;for(int i=0; i<mid; ++i)sum+=q[i];if(!cnt[u]){dp[u][1]=sum+(c[u]==0?0:p[u]);dp[u][2]=sum+(c[u]==1?0:p[u]);}else if(cnt[u]&1)dp[u][0]=min(sum+(c[u]==1?0:p[u]),sum+q[mid]+(c[u]==0?0:p[u]));else{dp[u][1]=min(sum+(c[u]==0?0:p[u]),sum-q[mid-1]+(c[u]==1?0:p[u]));dp[u][2]=min(sum+(c[u]==1?0:p[u]),sum+q[mid]+(c[u]==0?0:p[u]));}cnt[u]++;//自己是一个点
}
void mysolve()
{int n;cin>>n;int k,x;for(int i=1; i<=n; ++i){cin>>c[i]>>p[i]>>k;for(int j=1; j<=k; ++j)cin>>x,edge[i].push_back(x),in[x]++;}for(int i=1; i<=n; ++i)if(!in[i]){memset(dp,0x3f,sizeof(dp));dfs(i);int ans=min({dp[i][0],dp[i][1],dp[i][2]});cout<<ans<<endl;}
}int32_t main()
{mysolve();return 0;
}

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

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

相关文章

JavaWeb-Tomcat

目录 1.什么是Tomcat 2.Tomcat 概述 3.Tomcat基本使用 1.什么是Tomcat Tomcat官网&#xff1a;Apache Tomcat - Welcome! 【摘自百度百科】 Tomcat是Apache 软件基金会&#xff08;Apache Software Foundation&#xff09;的Jakarta 项目中的一个核心项目&#xff0c;由Apac…

MySQL: 数据类型之整数型、浮点数、时间日期

目录 前言&#xff1a; 数据类型&#xff1a; 整数型&#xff1a; 浮点数与定点数&#xff1a; 浮点数&#xff1a; 定点数&#xff1a; 日期与时间&#xff1a; DATATIME: DATE&#xff1a; TIMESTAMP: ​编辑 YEAR: TIME: 前言&#xff1a; 前面的几篇写了如何创…

2023年主流的选择仍是Feign, http客户端Feign还能再战

&#x1f473;我亲爱的各位大佬们好&#x1f618;&#x1f618;&#x1f618; ♨️本篇文章记录的为 微服务组件之http客户端Feign 相关内容&#xff0c;适合在学Java的小白,帮助新手快速上手,也适合复习中&#xff0c;面试中的大佬&#x1f649;&#x1f649;&#x1f649;。 …

音视频开发面试题大盘点:掌握这些基础知识,你就能轻松应对面试

前言 音视频开发作为一种高技术含量的领域&#xff0c;随着人们对数字媒体的需求不断增加&#xff0c;其前景非常广阔。预计在2023年&#xff0c;音视频开发领域仍将继续保持快速发展的态势&#xff0c;尤其是在移动互联网、物联网、虚拟现实、增强现实等领域。 根据BOSS招聘…

Jenkins Kubernetes

Kubernetes集成Harbor Harbor 私服配置 在Kubernetes的master和所有worker节点上加上harbor配置&#xff0c;修改daemon.json&#xff0c;支持Docker仓库&#xff0c;并重启Docker。 sudo vim /etc/docker/daemon.json {"registry-mirrors": ["https://jrabv…

微信小程序 开发中的问题(simba_wx)

目录 一、[将 proto 文件转成 json 文件](https://blog.csdn.net/wzxzRoad/article/details/129300513)二、[使用 test.json 文件](https://blog.csdn.net/wzxzRoad/article/details/129300513)三、[微信小程序插件网址](https://ext.dcloud.net.cn/)四、[vant-weapp网址](http…

从0搭建Vue3组件库(八):使用 release-it 实现自动管理发布组件库

使用 release-it 实现自动管理发布组件库 上一篇文章已经打包好我们的组件库了,而本篇文章将介绍如何发布一个组件库。当然本篇文章介绍的肯定不单单只是发布那么简单。 组件库发布 我们要发布的包名为打包后的 easyest,因此在 easyest 下执行pnpm init生成package.json {&…

本地缓存解决方案Caffeine | Spring Cloud 38

一、Caffeine简介 Caffeine是一款高性能、最优缓存库。Caffeine是受Google guava启发的本地缓存&#xff08;青出于蓝而胜于蓝&#xff09;&#xff0c;在Cafeine的改进设计中借鉴了 Guava 缓存和 ConcurrentLinkedHashMap&#xff0c;Guava缓存可以参考上篇&#xff1a;本地缓…

【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(九)Nacos+Sentinel+Seata

NacosSentinelSeata 9/9 1、SpringCloud Alibaba简介1.1 主要功能1.2 具体组件 2、SpringCloud Alibaba Nacos服务注册和配置中心2.1 Nacos介绍2.2 Nacos下载安装2.3 使用Nacos作为注册中心2.3.1 在父工程的pom文件中引入springcloudalibaba依赖2.3.2 创建cloudalibaba-provide…

适合学生党的蓝牙耳机品牌有哪些?性价比高的无线耳机推荐

相较于有线耳机&#xff0c;蓝牙耳机的受欢迎程度可谓是越来越高&#xff0c;当然&#xff0c;这也离不开部分手机取消耳机孔的设计。最近看到很多网友问&#xff0c;适合学生党的蓝牙耳机品牌有哪些&#xff1f;针对这个问题&#xff0c;我来给大家推荐几款性价比高的无线耳机…

static_cast、dynamic_cast和reinterpret_cast区别和联系

其实网上相关的资料不少&#xff0c;但是能够说清楚明白这个问题的也不多。 于是&#xff0c;我尝试着问了一下AI&#xff0c;感觉回答还可以&#xff0c;但是需要更多的资料验证。 让我们先看看AI是怎么回答这个问题的。 static_cast、dynamic_cast和reinterpret_cast都是C中…

视频音频提取器推荐:快速提取视频中的音频!

视频中的音频可以用于很多用途&#xff0c;比如制作配乐、音频剪辑等。但是&#xff0c;许多人并不知道如何将视频中的音频提取出来。如果您也是这样的情况&#xff0c;那么本文为您介绍一个简单易用的视频音频提取器&#xff1a;。 它是一个免费的在线工具&#xff0c;可以帮…

如何在Web上实现激光点云数据在线浏览和展示?

无人机激光雷达测量是一项综合性较强的应用系统&#xff0c;具有数据精度高、层次细节丰富、全天候作业等优势&#xff0c;能够精确测量三维现实世界&#xff0c;为各个行业提供了丰富有效的数据信息。但无人机激光雷达测量产生的点云数据需要占用大量的存储空间&#xff0c;甚…

DataGridView 真·列头不高亮 真·列头合并

高亮BUG VB.Net&#xff0c;在 .NET Framework 4.8 的 WinForm 下(即不是 WPF 的绘图模式、也不是 Core 或 Mono 的开发框架)&#xff0c;使用 DataGridView 行模式&#xff0c;还是有个列头表现为高亮显示&#xff1a; 查找各种解决方式: 设置 ColumnHeadersDefaultCellSty…

YOLOv1代码复现2:数据加载器构建

YOLOv1代码复现2&#xff1a;数据加载器构建 前言 ​ 在经历了Faster-RCNN代码解读的摧残后&#xff0c;下决心要搞点简单的&#xff0c;于是便有了本系列的博客。如果你苦于没有博客详细告诉你如何自己去实现YOLOv1&#xff0c;那么可以看看本系列的博客&#xff0c;也许可以帮…

【Java实战篇】Day13.在线教育网课平台--生成支付二维码与完成支付

文章目录 一、需求&#xff1a;生成支付二维码1、需求分析2、表设计3、接口定义4、接口实现5、完善controller 二、需求&#xff1a;查询支付结果1、需求分析2、表设计与模型类3、接口定义4、接口实现步骤一&#xff1a;查询支付结果步骤二&#xff1a;保存支付结果&#xff08…

VUE3如何定义less全局变量

默认已经安装好了less&#xff0c;这里不过多讲。 &#xff08;1&#xff09;首先我们需要下载一个插件依赖&#xff1a; npm i style-resources-loader --save-dev &#xff08;2&#xff09;VUE3里配置vue.config.js文件内容 代码&#xff1a; const path require("p…

HashMap如何解决哈希冲突

HashMap如何解决哈希冲突 Hash算法和Hash表Hash冲突解决哈希冲突的方法开放地址法链式寻址法再hash法建立公共溢出区 Hash算法和Hash表 Hash算法就是把任意长度的输入通过散列算法编程固定长度的输出。这个输出结果就是一个散列值。 Hash表又称为“散列表”&#xff0c;它是通…

SpringBoot中一个注解优雅实现重试Retry框架

目录: 1、简介2、实现步骤 1、简介 重试&#xff0c;在项目需求中是非常常见的&#xff0c;例如遇到网络波动等&#xff0c;要求某个接口或者是方法可以最多/最少调用几次&#xff1b;实现重试机制&#xff0c;非得用Retry这个重试框架吗&#xff1f;那肯定不是&#xff0c;相信…

Mysql 查询同类数据中某一数字最大的所有数据

方法一、将时间进行排序后再分组 该表表名为customer, park_id表示园区id&#xff0c;joined_at表示用户的加入时间&#xff0c;created_at表示用户的创建时间。 需求&#xff1a;查出每个园区中&#xff0c;最早加入园区的第一位用户 select * from (select * from custome…