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

建设留学网站做网站还是移动开发

建设留学网站,做网站还是移动开发,兰州网站seo优化,wordpress 点踩点分治学习笔记 模板题[洛谷P3806] 题意#xff1a;给定一棵有n个点的树#xff0c;询问树上距离为k的点对是否存在。 做法#xff1a;对于一个点\(u\)#xff0c;树上所有的路径可以分为两类#xff0c;一类是经过点\(u\)#xff0c;另一类是没有经过点\(u\)#xff0c… 点分治学习笔记 模板题[洛谷P3806] 题意给定一棵有n个点的树询问树上距离为k的点对是否存在。 做法对于一个点\(u\)树上所有的路径可以分为两类一类是经过点\(u\)另一类是没有经过点\(u\)即整条路径位于\(u\)的某个子树中。那么我们就可以对于点\(u\)统计出经过他的路径是否可以构成\(k\)然后删去点\(u\)对于每个子树的挑一个点作为根\(v\)重复同样的操作。这样我们就统计出了所有的路径。 然后我们注意到如果这棵树是一条链最坏的情况复杂度会下降为\(O(n^2)\)为了解决这个问题我们每次选取当前这棵树的重心作为根来分治就可以将最坏复杂度降为\(O(nlogn)\)为了写起来方便我的代码多了一个\(log\) Code: #include bits/stdc.h #define rep(i,a,b) for(int ia;ib;i) #define pb push_back #define Pii pairint,int #define x first #define y second const int N 10005; template class T inline void read(T x) {x 0; T f 1; char c getchar();while(!isdigit(c)) { if(c -) f -1; c getchar(); }while(isdigit(c)) { x x * 10 c - 0; c getchar(); }x * f; } using namespace std; int n, m, K[111], Ans[111]; struct edge{int e, w, nxt;} E[N 1]; int h[N], cc; void add(int u, int v, int w) {E[cc].e v; E[cc].w w;E[cc].nxt h[u]; h[u] cc; cc; } int used[N], sz[N], mxp[N]; mapint,int dep; setint S; int idx, MN; void dfs(int u, int pre, int num) {sz[u] 1; mxp[u] 0;for(int i h[u]; ~i; i E[i].nxt) if(!used[E[i].e] E[i].e ! pre){int v E[i].e;dfs(v, u, num);sz[u] sz[v];mxp[u] max(mxp[u], sz[v]);}mxp[u] max(mxp[u], num-sz[u]);if(mxp[u] MN) MN mxp[u], idx u; } int fdrt(int u,int sum) {idx 0, MN __INT_MAX__;dfs(u,0,sum);return idx; } void bfs(int u, int w) {dep[u] w;queueint q; q.push(u);while(!q.empty()) {int u q.front(); q.pop();for(int i h[u]; ~i ; i E[i].nxt) if(!used[E[i].e] dep.find(E[i].e) dep.end()) {int v E[i].e;dep[v] dep[u] E[i].w;q.push(v);}} } int M[N]; void solve(int u) {used[u] 1; S.clear(); S.insert(0);for(int i h[u]; ~i; i E[i].nxt) if(!used[E[i].e]) {int v E[i].e, w E[i].w;dep.clear();bfs(v,w);for(auto A: dep) {for(int j 1; j m; j) {if(S.find(K[j] - A.y) ! S.end()) Ans[j] | 1;}}for(auto A: dep) S.insert(A.y);M[v] dep.size();}for(int i h[u]; ~i; i E[i].nxt) if(!used[E[i].e]) {solve( fdrt(E[i].e, M[E[i].e]) );} } int main() {read(n); read(m); int u, v, w; memset(h, -1, sizeof(h));rep(i,2,n) read(u), read(v), read(w), add(u,v,w), add(v,u,w);rep(i,1,m) read(K[i]);int rt fdrt(1,n);solve(rt);rep(i,1,m) puts(Ans[i] ? AYE : NAY); } 转载于:https://www.cnblogs.com/RRRR-wys/p/10501688.html
http://www.zqtcl.cn/news/525616/

相关文章:

  • 深圳做微商网站的公司高端做网站价格
  • 在线原型设计网站wordpress菜单页内跳转
  • 做电影网站要买什么抖音推广怎么收费
  • 专业的公司网站开发网站按钮设计
  • 南宁网站建设是什么深圳公司有哪些
  • 杭州手机申请网站登录怎么做电子商务网站
  • 青岛个人接网站建设wordpress 转载文章
  • 网上做网站任务网络营销传播的核心内容
  • 做黑界头像网站成考过来人的忠告
  • 宁波网站建设是哪家便宜织梦网站数据库备份文件夹
  • 在北京大学生做家教的网站淘宝网页
  • 英铭网站建设网站如何推广引流
  • 关于电子商务网站建设的现状企业公示信息查询系统山西
  • 网站开发 翻译长春建站企业
  • dedecms网站网站解析一般什么时候
  • 制作网站的技术北京律师24小时电话
  • 可拖拽 网站建设如何做自媒体和网站签约赚点击
  • 做网站选哪个语言怎么登录百度app
  • 国发网站建设网站优化主要优化哪些地方
  • 快速微信网站开发定制网站建设费用预算
  • 网站制作叫什么知名网站建设制作
  • 网络营销网站建设公司h5应用
  • 网站开发合同要上印花税吗南江红鱼洞水库建设管理局网站
  • 疏通下水道网站怎么做wordpress 恢复初始化
  • 电脑商业网站怎的做软文推广渠道
  • 自己做网站需要买什么如何做微信商城网站
  • 有了网站开发app是不是更容易自建网站管理
  • 网站将要准备建设的内容有哪些做外贸有效的网站
  • 网站设计博客网站内容添加
  • 网站建站行业新闻微盟开店怎么收费