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

网站定制建设公司站长工具seo查询5g5g

网站定制建设公司,站长工具seo查询5g5g,建设网站终身免费,张店网站建设哪家好龙龙是“饱了呀”外卖软件的注册骑手,负责送帕特小区的外卖。帕特小区的构造非常特别,都是双向道路且没有构成环 —— 你可以简单地认为小区的路构成了一棵树,根结点是外卖站,树上的结点就是要送餐的地址。 每到中午 12 点&#…

龙龙是“饱了呀”外卖软件的注册骑手,负责送帕特小区的外卖。帕特小区的构造非常特别,都是双向道路且没有构成环 —— 你可以简单地认为小区的路构成了一棵树,根结点是外卖站,树上的结点就是要送餐的地址。

每到中午 12 点,帕特小区就进入了点餐高峰。一开始,只有一两个地方点外卖,龙龙简单就送好了;但随着大数据的分析,龙龙被派了更多的单子,也就送得越来越累……

看着一大堆订单,龙龙想知道,从外卖站出发,访问所有点了外卖的地方至少一次(这样才能把外卖送到)所需的最短路程的距离到底是多少?每次新增一个点外卖的地址,他就想估算一遍整体工作量,这样他就可以搞明白新增一个地址给他带来了多少负担。

输入格式:

输入第一行是两个数 N 和 M (2≤N≤105, 1≤M≤105),分别对应树上节点的个数(包括外卖站),以及新增的送餐地址的个数。

接下来首先是一行 N 个数,第 i 个数表示第 i 个点的双亲节点的编号。节点编号从 1 到 N,外卖站的双亲编号定义为 −1。

接下来有 M 行,每行给出一个新增的送餐地点的编号 Xi​。保证送餐地点中不会有外卖站,但地点有可能会重复。

为了方便计算,我们可以假设龙龙一开始一个地址的外卖都不用送,两个相邻的地点之间的路径长度统一设为 1,且从外卖站出发可以访问到所有地点。

注意:所有送餐地址可以按任意顺序访问,且完成送餐后无需返回外卖站

输出格式:

对于每个新增的地点,在一行内输出题目需要求的最短路程的距离。

输入样例:

7 4
-1 1 1 1 2 2 3
5
6
2
4

输出样例:

2
4
4
6

画几次图模拟一下过程,可以发现,如果要回到起点的话,每条边要走2次,不回起点的话,就可以去掉最长的那条路。

问题分析

龙龙需要从外卖站出发,访问所有订单地址至少一次,求最短路径。关键点:

  1. 树结构:小区道路构成一棵树,外卖站是根节点。

  2. 动态更新:每次新增订单地址后,计算访问所有地址的最短路径。

  3. 无需返回:送完最后一个订单后无需返回外卖站。

关键观察

  1. 每条边最多走两次

    • 如果最终返回外卖站,每条边会被走两次(一来一回)。

    • 如果不返回,可以省去从最深节点返回的路径。

  2. 最短路径公式

    • 总路径 = 2 × 总边数 - 最长深度

      • 2 × 总边数:所有边都往返走一次。

      • - 最长深度:最深节点不用返回,节省的路径。

算法设计

  1. 预处理

    • 使用 DFS 或 BFS 计算每个节点到根节点的深度(距离)。

    • 使用记忆化搜索优化重复计算。

  2. 动态维护

    • sum:当前所有订单地址构成的子树的边数。

    • mx:当前所有订单地址中的最大深度。

  3. 查询处理

    • 每新增一个地址,更新 sum 和 mx

    • 输出 2 × sum - mx

代码如下:

#include <iostream>
#include <vector>
#include <map>
using namespace std;vector<int> dist;
vector<int> fa;
int sum = 0, mx = 0;int dfs(int r) {if (fa[r] == -1 || dist[r] > 0) {return dist[r];} //记忆化搜索sum++; //说明是一条新的边,边总数+1dist[r] = dfs(fa[r]) + 1;return dist[r];
}int main() {int n, m, x;cin >> n >> m;fa = vector<int>(n + 1);dist = vector<int>(n + 1);for (int i = 1; i <= n; i++) {cin >> fa[i];}while (m--) {cin >> x;mx = max(mx, dfs(x));cout << sum * 2 - mx << endl;//可以看出规律每条边都恰好走两边//最后不用返回就见一条最大的边}return 0;
}

http://www.dtcms.com/wzjs/527005.html

相关文章:

  • 网站策划书包含的内容沈阳百度seo关键词排名优化软件
  • 朋友做的网站图片不显示北京网站建设专业公司
  • 济南手机建站模板百度seo是啥意思
  • 财佰通突然做网站维护企业培训课程有哪些内容
  • 企业安全文化建设的核心内容宁波谷歌优化
  • 微信小程序什么时候上线的南京网络推广优化哪家好
  • 网页设计素材为什么拖不进ps整站优化深圳
  • 答题助手网站怎么做的查看关键词被搜索排名的软件
  • 宁波北京网站建设美业推广平台
  • 成都web设计河南整站关键词排名优化软件
  • 网站建设能用手机制作吗微信朋友圈广告推广代理
  • 网络规划设计师和中级对比东莞seo培训
  • 做网站在什么地方发帖子呢产品推广找哪家公司
  • 电子商务网站设计原理真题品牌推广手段
  • 网站开发费用多少电工培训课程
  • 做设计兼职的网站有哪些工作企业网络搭建方案
  • 税务局网站公司实名制怎么做太原百度公司地址
  • 校园网站建设年度总结汕头百度网络推广
  • 江阴做网站的企业网站搭建免费
  • wap网站源码.net河北疫情最新情况
  • 政府网站建设以什么为宗旨发布悬赏任务的推广平台
  • 专做水果店加盟的网站网站搭建平台
  • 建站工具也成为什么系统公关团队
  • 临海网站设计新闻营销发稿平台
  • 想做个网站不知道怎么做广告推广计划
  • 做网站费用广州seo
  • wordpress网易云插件惠州百度seo找谁
  • 免费应用软件下载搜索引擎广告优化
  • 深圳设计网站推荐免费推客推广平台
  • 专业网站建设科技公司北京seo公司助力网络营销