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

南京雨花台区做网站域名注册官网免费

南京雨花台区做网站,域名注册官网免费,阿里云怎么建网站,商城网站建设新闻URL:https://atcoder.jp/contests/abc309 目录 E Problem/题意 Thought/思路 解法一: 解法二: Code/代码 E Problem/题意 一个家庭有 N 个人,根节点为 1,给出 2 ~ N 的父节点。一共购买 M 次保险,每…

URL:https://atcoder.jp/contests/abc309

目录

E

Problem/题意

Thought/思路

解法一:

解法二:

 Code/代码


E

Problem/题意

一个家庭有 N 个人,根节点为 1,给出 2 ~ N 的父节点。一共购买 M 次保险,每次给出 Xi Yi,使得 Xi 和它之后的 Yi 代人都有保险。问一共有多少人获得保险?

Thought/思路

解法一:

用 next[i] 表示从 i 出发,还能覆盖多少代保险。假设 x 是 i 的下一个节点,那么 next[x] = Max(next[x], next[i] - 1)。通解只需要将 i 改为 fa[x] 即可。

只要当前节点的 next >= 0,就能让 ans ++。

解法二:

来自:~Lanly~

该解法的核心思想就是,当前处理的点,有且仅有一条回到根节点的路线,也因此可以将其当作一维前缀和来处理。

Code/代码

解法一:

#include "bits/stdc++.h"int n, m, fa[300005], next[300005], ans;std::vector <int> g[300005];void dfs(int fa, int x) {next[x] = std::max(next[x], next[fa] - 1);if (next[x] >= 0) ans ++;for (auto &o : g[x]) {dfs(x, o);}
}signed main() {std::cin >> n >> m;for (int i = 2; i <= n; ++ i) {std::cin >> fa[i];g[fa[i]].push_back(i);}std::memset(next, -1, sizeof next);for (int i = 1; i <= m; ++ i) {int x, y; std::cin >> x >> y;next[x] = std::max(next[x], y);}dfs(0, 1);std::cout << ans;
}

解法二:

#include "bits/stdc++.h"int n, m, ans, sum; // sum 是dfs每条链时的前缀和
int pre[300005], next[300005], vis[300005];
std::vector <int> g[300005];void dfs(int x, int depth) { // depth 是从 x 的层数开始算的层vis[x] = 1;if (next[x] > 0) { sum += 1; // 遇到一个能覆盖的点,该链上的和加 1pre[std::min(n + 1, depth + next[x] + 1)] -= 1; // 接下来的某层覆盖不到,差分数组减 1}sum += pre[depth]; // 前缀和 = 本身的值 + 当前的差分数组if (sum > 0) ans ++;for (auto &v : g[x]) {dfs(v, depth + 1);}sum -= pre[depth]; // 回溯if (next[x] > 0) {sum -= 1;pre[std::min(n + 1, depth + next[x] + 1)] += 1;}}signed main() {std::cin >> n >> m;for (int i = 2; i <= n; ++ i) {int x; std::cin >> x;g[x].push_back(i);}for (int i = 1; i <= m; ++ i) {int x, y; std::cin >> x >> y;next[x] = std::max(next[x], y);}for (int i = 1; i <= n; ++ i) {if (!vis[i]) dfs(i, 0);}std::cout << ans;
}

http://www.shuangfujiaoyu.com/news/37241.html

相关文章:

  • 临淄网站制作首选专家百度投诉中心24人工 客服电话
  • 长沙网站推广新媒体营销推广方案
  • 长沙 网站建设产品如何做线上推广
  • 网站制作维护发票产品50个关键词
  • 现工作室专做网站建设等应用程序项目,但工作室名暂为新开传奇网站
  • 好看的页面设计重庆放心seo整站优化
  • 网站开发团队需要哪些人全网品牌推广
  • 公司网站上的员工风采怎么做站长工具箱
  • 宠物网站页面设计简笔长沙百度关键词推广
  • 开发建设网站多久网络营销公司名字大全
  • 安全的南昌网站制作子域名大全查询
  • php 企业网站模板小程序开发哪家好
  • 网站访问慢原因百度竞价推广点击器
  • 网站推广一般在哪个网做yy直播
  • wordpress建站vip全站教程郑州seo公司排名
  • 南京建设工程社会保障网站推广品牌
  • 个人介绍网站怎么做搜索引擎优化排名技巧
  • 路得威网站谁做的做百度推广需要什么条件
  • 深圳CSS3网站建设价格优秀的营销案例
  • 做内衣的网站好焊工培训
  • wordpress好看的中文主题佛山seo优化外包
  • 潍坊网站建设兼职流量查询网站
  • wordpress 小米路由器关于进一步优化
  • web网站发布怎么做seo职业发展
  • chn域名注册网站营销策划方案
  • 成都网站建设冠辰济南seo优化
  • apmserv网站模板国内免费域名注册
  • 合肥宣传网站营销技巧和营销方法心得
  • 驾校网站制作如何优化网页
  • 最新网站信息百度推广广告收费标准