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

做网站在阿里云买什么软件免费b站推广软件

做网站在阿里云买什么软件,免费b站推广软件,网站seo合同,中国供应商网官网首页树在算法题中非常常见,今天就用一篇文章来入门树的相关知识 目录 树的存储 存储原理 代码模版 树的遍历 1树的深度优先遍历(dfs递归实现) 代码模版 2树的广度优先遍历(bfs队列实现) 代码模版 关联知识-拓扑…

树在算法题中非常常见,今天就用一篇文章来入门树的相关知识

目录

树的存储

存储原理

代码模版

树的遍历

1树的深度优先遍历(dfs递归实现)

代码模版 

2树的广度优先遍历(bfs队列实现)

代码模版

关联知识-拓扑排序

拓扑排序是什么

拓扑排序怎么写


树的存储

存储原理

可以用邻接矩阵或邻接表,邻接矩阵就是二维数组,邻接表是以链表方式进行存储

代码模版

一个头结点:
所需变量:int h,ne[N],e[N],idx;
解释:h存的是头结点地址,ne[N]存的是每一个节点的下一个节点的地址,(就是数据结构结构体里面的s->next)
e[N]存的是该地址下的值,idx相当于是指针;
具体操作(头插法):
void cs(int a,int b)
{e[idx]=b,ne[idx]=h[a],h[a]=idx++;
}
遍历模版
for(int i=h[u];i!=-1;i=ne[i]){int j=e[i];....}

树的遍历

1树的深度优先遍历(dfs递归实现)
https://www.acwing.com/problem/content/848/

#include<bits/stdc++.h>
using namespace std;
const int N=1e5+10;
int h[N],e[N*2],ne[N*2];
int ans=N,idx,n;
bool st[N];
void cs(int a,int b)
{e[idx]=b,ne[idx]=h[a],h[a]=idx++;
}
int dfs(int u)
{st[u]=1;int sum=1,res=0;for(int i=h[u];i!=-1;i=ne[i]){int j=e[i];if(st[j])continue;int s=dfs(j);res=max(s,res);sum+=s;}res=max(res,n-sum);ans=min(ans,res);return sum;
}
int main()
{cin >> n;memset(h,-1,sizeof h);for(int i=0;i<n-1;i++){int a,b;cin >> a >> b;cs(a,b),cs(b,a);}dfs(1);cout << ans;
}

2树的广度优先遍历(bfs队列实现)

​​​​https://www.acwing.com/problem/content/849/

#include<bits/stdc++.h>
using namespace std;
const int N=1e5+10;
int n,m;
int h[N],e[N],ne[N],idx;
int d[N];
void cr(int a,int b)
{e[idx]=b,ne[idx]=h[a],h[a]=idx++;
}
int bfs()
{memset(d,-1,sizeof d);d[1]=0;queue<int>q;q.push(1);while(!q.empty()){int t=q.front();q.pop();for(int i=h[t];i!=-1;i=ne[i]){int j=e[i];if(d[j]==-1){d[j]=d[t]+1;q.push(j);}}}return d[n];
}
int main()
{cin >> n >> m;memset(h,-1,sizeof h);for(int i=0;i<m;i++){int a,b;cin >> a >> b;cr(a,b);}cout << bfs()<<endl;
}

关联知识-拓扑排序

拓扑排序是什么

简而言之就是,把数的节点变成一个序列,序列当中每个点都满足:在树中该点指向的点在序列的位置位于该点之后,在树中指向该点的点在序列的位置位于该点之前。

拓扑排序怎么写

#include<bits/stdc++.h>
using namespace std;
const int N=1e5+10;
int n,m;
int h[N],ne[N],e[N],idx;
int d[N],ans[N],cnt;
queue<int>q;
void cr(int a,int b)
{e[idx]=b,ne[idx]=h[a],h[a]=idx++;
}
bool bfspd()
{for(int i=1;i<=n;i++){if(d[i]==0){q.push(i);//把每一个入度为0的点入队}}while(!q.empty()){int t=q.front();q.pop();ans[cnt++]=t;//存储队头的值,队头的值就是入度为零的点for(int i=h[t];i!=-1;i=ne[i]){int j=e[i];d[j]--;//断链,入度-1if(d[j]==0){q.push(j);}}}return cnt==n;
}
int main()
{cin >> n >> m;memset(h, -1, sizeof h);for(int i=0;i<m;i++){int a,b ;cin >> a >> b;cr(a,b);d[b]++;//记录每一个点的入度数量}if(bfspd())for(int i=0;i<n;i++){cout << ans[i]<<' ';}else cout << "-1";
}

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

相关文章:

  • 手机客户端网站建设windows优化大师免费版
  • 我想建个赌博网站怎么建域名网络营销的优势与不足
  • 大兴手机网站建设郑州seo优化
  • 天津企业网站专业订制惠州搜索引擎seo
  • wordpress授权登录界面seo系统培训课程
  • 设计网站首页网络营销是以什么为基础
  • 阜阳做网站的公司软件开发公司联系方式
  • 网站建设湛江防控措施持续优化
  • 建设部设计规范网站网络营销的模式有哪些?
  • 河南网站制作价格头条搜索
  • 网站开发工程师需要具备的综合素质seo优化排名经验
  • 收费用的网站怎么做最近五天的新闻大事
  • 百度网站公司信息推广怎么做推广有奖励的app平台
  • 网站栏目设置说明软文世界官网
  • 郑州营销型网站制作教程好看的html网页
  • 青海公路建设信用信息服务网站自己怎么开网站
  • 校园二手网站开发与设计任务书开网站需要多少钱
  • 手机网站转微信小程序产品怎么在网上推广
  • 建宁建设局网站制作一个网站的全过程
  • 淘宝客 网站备案友情链接怎么做
  • 饭店网站建设策划方案大数据精准营销案例
  • 北京网站设计制作关键词优化网络营销的十种方法
  • 做兽药网站用什么图片好楚雄今日头条新闻
  • 龙岗企业网站制作公司优化推广网站seo
  • 服务器网站慢的原因信息流广告投放流程
  • 公司的网站建设费会计分录广告推广接单平台
  • 网站建设本科毕业论文广州营销型网站
  • 电商网站里的水果图片怎么做的重庆网站seo搜索引擎优化
  • 郑州商城网站建设媒体网络推广价格优惠
  • 开发网站的硬件成本个人引流推广怎么做