#Z2322. 买保险

一.题目

二.思路

1.暴力

训练的时候,初看这道题,这不就打个暴力吗?

 2.暴力代码

#include<bits/stdc++.h>
#define int long long
using namespace std;
int n,m,fa,x,y,vis[1000001],ans;
vector<int> vec[1000001];
void dfs(int x,int y)
{if(y == -1) return ;vis[x] = 1;for(int i = 0;i < vec[x].size();i++) dfs(vec[x][i],y - 1);
}
signed main()
{cin>>n>>m;for(int i = 2;i <= n;i++){cin>>fa;vec[fa].push_back(i);}while(m--){cin>>x>>y;dfs(x,y);}for(int i = 1;i <= n;i++)if(vis[i])ans++;cout<<ans;return 0;
}

结果。。。

3.正解

赛后仔细研究了一下,其实也不难,只要借鉴一下线段树lazy标记的思想,打个标记,dfs的时候下传就行了。细节有点多,可以看看代码。

4.代码

#include<bits/stdc++.h>
#define int long long
using namespace std;
int n,m,fa,x,y,vis[1000001],ans,t[1000001];
vector<int> vec[1000001];
void dfs(int x,int fa,int y)
{t[x] = max(t[x],y);//因为有可能父节点下传了保险,自己也买了一份保险if(t[x]) vis[x] = 1;for(int i = 0;i < vec[x].size();i++)if(fa != vec[x][i]){if(t[x] - 1 >= 0) dfs(vec[x][i],x,t[x] - 1);else dfs(vec[x][i],x,0);}
}
signed main()
{cin>>n>>m;for(int i = 2;i <= n;i++){cin>>fa;vec[fa].push_back(i);vec[i].push_back(fa);}while(m--){cin>>x>>y;y++;t[x] = max(t[x],y);//因为一个人有可能买多份保险,所以要取其中往后最多的子孙的那一份}dfs(1,0,0);for(int i = 1;i <= n;i++)if(vis[i])ans++;cout<<ans;return 0;
}

 三.结语

如果这篇博客对您有帮助的话,请点个赞支持一下吖!( •̀ ω •́ )✧

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

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

相关文章

6.824-Lab 1: MapReduce

lab1链接&#xff1a;6.824 Lab 1: MapReduce (mit.edu) 介绍 在这个实验中&#xff0c;你将构建一个MapReduce系统。你将实现一个工作进程&#xff08;worker process&#xff09;&#xff0c;调用应用程序的Map和Reduce函数&#xff0c;并处理文件的读写&#xff0c;以及一…

如何实现高效的Web自动化测试?

随着互联网的快速发展&#xff0c;Web应用程序的重要性也日益凸显。为了保证Web应用程序的质量和稳定性&#xff0c;Web自动化测试成为必不可少的一环。然而&#xff0c;如何实现高效的Web自动化测试却是一个值得探讨的课题。 首先&#xff0c;选择合适的测试工具是关键。市面…

Android 13.0 原生SystemUI下拉通知栏每条通知默认展开

1.前言 在13.0的系统rom原生开发中,在在对SystemUI下拉通知栏做定制的时候,在下拉状态栏的时候,通知栏中最后一条通知默认是收缩的 点击按钮 就会展开 原生系统systemui就是如此,为了更美观 所以要求最后一条通知也默认展开,显得更美观 最终效果图: 2.原生SystemUI下拉通…

【Eclipse插件开发】3工作台workbench探索【下篇】

【Eclipse插件开发】3工作台workbench探索【下篇】 文章目录 【Eclipse插件开发】3工作台workbench探索【下篇】一、Plugin 类AbstractUIPlugin二、偏好设置2.1 添加一个偏好设置页面2.2 实现用户偏好设置页面定义页面插件偏好存储查找和保存用户偏好设置2.3 编辑区域一、Plugi…

THM学习笔记——枚举

复制以下内容时注意中英文符号区别 在枚举之前我们要将shell升级为完全交互式的tty。 这涉及以下几条命令 python -c import pty;pty.spawn("/bin/bash") stty raw -echo export TERMxterm rlwrap nc -lvnp 443 从以上选一条即可 手动枚举 以下命令只需了解即可&…

VS Code中主程序C文件引用了另一个.h头文件,编译时报错找不到函数

目录 一、问题描述二、问题原因三、解决方法四、扩展五、通过CMake进行配置 一、问题描述 VS Code中主程序C文件引用了另一个.h头文件&#xff0c;编译时报错找不到函数 主程序 main.c #include <stdio.h> #include "sumaa.h"int main(int, char**){printf(&q…

thinkphp获取用户最新的阅读记录,按书籍id去重,返回最新的阅读记录

通过uid查询data_user_zhangjie的记录 去重shuji_id 获取createtime最新的一条数据 //获取用户章节记录public function getUserZhangjieList(){$uid = input(uid);if(empty

接雨水【中等难度】

接雨水【中等难度】 题目解题思路代码复杂度分析题目 题目:接雨水 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。 示例 1: 输入:height = [0,1,0,2,1,0,1,3,2,1,2,1] 输出:6 解释:上面是由数组 [0,1,0,2,1,0,1,3,2,…

微信小程序如何实现动态显示和隐藏某个控件

Hello大家好&#xff01;我是咕噜铁蛋&#xff01;微信小程序作为一种轻量级的应用开发平台&#xff0c;越来越受到开发者和用户的关注。在微信小程序的开发过程中&#xff0c;控制元素的显示和隐藏是一个常见的需求。通过动态显示和隐藏某个控件&#xff0c;我们可以根据用户的…

【洛谷 P1177】【模板】排序 题解(向量+排序)

【模板】排序 题目描述 将读入的 N N N 个数从小到大排序后输出。 输入格式 第一行为一个正整数 N N N。 第二行包含 N N N 个空格隔开的正整数 a i a_i ai​&#xff0c;为你需要进行排序的数。 输出格式 将给定的 N N N 个数从小到大输出&#xff0c;数之间空格隔…

机器学习 | 一文看懂SVM算法从原理到实现全解析

目录 初识SVM算法 SVM算法原理 SVM损失函数 SVM的核方法 数字识别器(实操) 初识SVM算法 支持向量机&#xff08;Support Vector Machine&#xff0c;SVM&#xff09;是一种经典的监督学习算法&#xff0c;用于解决二分类和多分类问题。其核心思想是通过在特征空间中找到一…

详述FlinkSql Join操作

FlinkSql 的 Join Flink 官网将其分为了 Joins 和 Window Joins两个大类&#xff0c;其中里面又分了很多 Join 方式 参考文档&#xff1a; Joins | Apache Flink Window JOIN | Apache Flink Joins 官网介绍共有6种方式&#xff1a; Regular Join&#xff1a;流与流的 Joi…

使用Softing edgeConnector模块将云轻松连接到Siemens PLC

一 工业边缘的连接解决方案 云服务提供商 (CSP) 引入了服务和功能&#xff0c;以简化基于云的工业物联网解决方案的实施。Azure Industrial IoT Platform或AWS IoT SiteWise支持标准协议和接口&#xff0c;例如OPC UA或MQTT。但是&#xff0c;如果您希望在典型的旧改项目中连接…

LeetCode803. Bricks Falling When Hit——洪水填充

文章目录 一、题目二、题解 一、题目 You are given an m x n binary grid, where each 1 represents a brick and 0 represents an empty space. A brick is stable if: It is directly connected to the top of the grid, or At least one other brick in its four adjacen…

VM安装Centos7

目标&#xff1a; 一&#xff0c;安装Centos7 二&#xff0c;ssh可以连接 1 新建虚拟机 一直下一步 2 直到此处&#xff0c;选择稍后安装 一直下一步直到完成。 3 选中虚拟机&#xff0c;点击设置 选择CD/DVD&#xff0c;选取ISO映像文件。 4 等待安装 并且设置root密码 5…

Redis -- zset有序集合

聪明在于勤奋&#xff0c;天才在于积累。 目录 zset 有序集合 zset相关命令 zadd zcard zcount zrange zrevrange zrangebyscore zpopmax bzpopmax zpopmin bzpopmin zrank zscore zrem zRemRangeByRank zRemRangeByScore zincrby 集合间操作 zinte…

java日志框架总结(五、logback日志框架)

一、logback概述 Logback是由log4j创始人设计的又一个开源日志组件。 Logback当前分成三个模块&#xff1a; 1、logback-core, 2、logback- classic 3、logback-access。 1&#xff09;logback-core是其它两个模块的基础模块。 2&#xff09;logback-…

【操作系统】Ubuntu Swap内存扩容

目录 背景 查看内存信息 确定当前的交换空间大小 查看内存使用情况 查看fstab文件,确认swap分区位置 查看swap分区大小 swap分区扩容 关闭swap分区 创建大的swap文件 格式化swap空间 关闭之前的swap 开启新swap 开机挂载 验证交换空间的大小 背景 在执行某些程序…

详解C++类和对象(中(类的6个默认成员函数))

文章目录 写在前面1. 类的6个默认成员函数2. 构造函数2.1 构造函数的引入2.1 构造函数的特性 3. 析构函数3.1 析构函数的引入3.2 析构函数的特性 4. 拷贝构造函数4.1 拷贝构造函数概念4.2 拷贝构造函数的特性4.3 拷贝构造函数典型调用场景 5. 赋值运算符重载5.1 运算符重载5.2 …

【Android】获取设备IP的方法

序言 在Android开发中&#xff0c;有很多地方需要使用IP地址&#xff0c;但是有时候Android设备获取的IP地址是有区别的&#xff0c;比如如果Android设备创建一个热点&#xff0c;那此时这个Android设备就有两个IP地址了&#xff0c;一个是本身的IP地址&#xff0c;一个是热点…