#Z2322. 买保险

一.题目

二.思路

1.暴力

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

2.暴力代码

cpp 复制代码
#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.代码

cpp 复制代码
#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;
}

三.结语

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

相关推荐
武子康7 分钟前
大数据-212 数据挖掘 机器学习理论 - 无监督学习算法 KMeans 基本原理 簇内误差平方和
大数据·人工智能·学习·算法·机器学习·数据挖掘
passer__jw76736 分钟前
【LeetCode】【算法】283. 移动零
数据结构·算法·leetcode
Ocean☾42 分钟前
前端基础-html-注册界面
前端·算法·html
顶呱呱程序1 小时前
2-143 基于matlab-GUI的脉冲响应不变法实现音频滤波功能
算法·matlab·音视频·matlab-gui·音频滤波·脉冲响应不变法
Tianyanxiao1 小时前
如何利用探商宝精准营销,抓住行业机遇——以AI技术与大数据推动企业信息精准筛选
大数据·人工智能·科技·数据分析·深度优先·零售
爱吃生蚝的于勒1 小时前
深入学习指针(5)!!!!!!!!!!!!!!!
c语言·开发语言·数据结构·学习·计算机网络·算法
羊小猪~~1 小时前
数据结构C语言描述2(图文结合)--有头单链表,无头单链表(两种方法),链表反转、有序链表构建、排序等操作,考研可看
c语言·数据结构·c++·考研·算法·链表·visual studio
王哈哈^_^2 小时前
【数据集】【YOLO】【VOC】目标检测数据集,查找数据集,yolo目标检测算法详细实战训练步骤!
人工智能·深度学习·算法·yolo·目标检测·计算机视觉·pyqt
星沁城2 小时前
240. 搜索二维矩阵 II
java·线性代数·算法·leetcode·矩阵
脉牛杂德2 小时前
多项式加法——C语言
数据结构·c++·算法