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

happytug wordpress真实的优化排名

happytug wordpress,真实的优化排名,精美网页模板,seo综合查询怎么用题目描述 给出 n 个点的一棵树,多次询问两点之间的最短距离。 注意:边是双向的。 输入描述 第一行为两个整数 n 和 m。n 表示点数,m 表示询问次数; 下来 n−1 行,每行三个整数 x,y,k,表示点 x 和点 y 之间…

题目描述
给出 n 个点的一棵树,多次询问两点之间的最短距离。
注意:边是双向的。

输入描述
第一行为两个整数 n 和 m。n 表示点数,m 表示询问次数;
下来 n−1 行,每行三个整数 x,y,k,表示点 x 和点 y 之间存在一条边长度为 k;
再接下来 m 行,每行两个整数 x,y,表示询问点 x 到点 y 的最短距离。

输出描述
输出 m 行。对于每次询问,输出一行。

样例输入
2 2
1 2 100
1 2
2 1
样例输出
100
100
对于全部数据,2≤ n n n 1 0 4 10^4 104,1≤ m m m 2 × 1 0 4 2×10^4 2×104,0< k k k 100 100 100,1≤ x , y x,y x,y n n n
首先这道题肯定是不能直接暴力跑的
但是换一个角度想,这是一棵树,先画个图:
在这里插入图片描述
比如说我们要求3到4的距离:
1,我们先找出3和4的公共祖先——2
2,把3的深度与4的深度加起来
3,减去重复的部分(根节点到最近公共祖先)
在这里插入图片描述
求任意两点的距离大概就是这个思路
然后来看一个重要的数组—— f f f数组
f [ i ] f[i] f[i]表示的是节点 i i i的祖先节点
f i n d ( ) find() find()函数的作用就是找到祖先节点
后面就是dfs遍历节点同时找最近公共祖先

#include<bits/stdc++.h>
using namespace std;
const int N=2e4+5;
struct node{int to,dis;
};
vector<node>a[N];
struct nod{int to,num;
};
vector<nod>q[N];
int n,m;
int vis[N],dis[N],res[N],f[N];
int find(int x){//找祖先函数if(f[x]!=x)f[x]=find(f[x]);return f[x];
}
void dfs(int x){vis[x]=1;for(int i=0;i<a[x].size();i++){//最近的公共祖先肯定要是最短路int v=a[x][i].to;int w=a[x][i].dis;if(vis[v]==0){dis[v]=dis[x]+w;dfs(v);f[v]=x;}}for(int i=0;i<q[x].size();i++){int to=q[x][i].to;int num=q[x][i].num;if(vis[to]==2){res[num]=dis[x]+dis[to]-2*dis[find(to)];//计算距离}}vis[x]=2;
}
signed main(){scanf("%d%d",&n,&m);for(int i=1;i<=n;i++)f[i]=i;for(int i=1;i<n;i++){int u,v,w;scanf("%d%d%d",&u,&v,&w);a[u].push_back(node{v,w});a[v].push_back(node{u,w});}for(int i=1;i<=m;i++){int x,y;scanf("%d%d",&x,&y);q[x].push_back(nod{y,i});q[y].push_back(nod{x,i});}dfs(1);for(int i=1;i<=m;i++)printf("%d\n",res[i]);//离线输出
}

最后,祝程序员们节日快乐









……祝方昳杨生日快乐……
还有……
对不起……

http://www.khdw.cn/news/60085.html

相关文章:

  • 付公司网站费用怎么做分录镇江网站建设
  • 沈阳做网站最好的公司有哪些深圳网站关键词优化推广
  • 找做金融的网站泸州网站优化推广
  • 小公司如何做网站培训学校管理制度大全
  • python做web的大型网站如何做网站
  • 企业网站建设费用做管理费用吗网站建设的数字化和互联网化
  • 网站木马诊断江西seo
  • 营销型网站源码酒店推广渠道有哪些
  • 网站注入木马小程序定制开发公司
  • 企业网站欣赏做一个简单网页
  • 科普互联网站建设seo优化系统
  • 南昌加盟网站制作策划品牌全案
  • php手机网站开发教程优化关键词哪家好
  • 上海网站建设网页设常熟网站建设
  • 专业做网站开发的公司深圳 网站制作
  • 新网站如何做百度关键词云南网络营销公司
  • 佛山网站专家怎么注册网站免费的
  • 自己做网站卖矿山设备免费seo推广软件
  • wordpress前端找回密码seo具体是什么
  • 建设网站比较好公司手机网站建设价格
  • 淄博营销网站建设公司宝鸡seo优化公司
  • 六合哪家做网站建设深圳关键词优化平台
  • 无聊的网站推广链接怎么自己搞定
  • 禅城区网站建设公司河南整站关键词排名优化软件
  • 泉州最专业手机网站建设定制石家庄百度搜索优化
  • 网站建设的基本流程最新营销模式有哪些
  • 互站网官网搜索引擎优化
  • 网站维护入门教程网站制作的基本流程
  • 网站接入商最新黑帽seo教程
  • 响应式网站建设效果seo是什么意思啊