AcWing 847. 图中点的层次
2024-09-05 04:58:44
队列
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <queue>
using namespace std;
const int N = ;
int n, m;
int h[N], e[N], ne[N], idx;
int d[N];
void add(int a, int b) {
e[idx] = b, ne[idx] = h[a], h[a] = idx ++ ;
}
int bfs() {
memset(d, -, sizeof d);
queue<int> q;
d[] = ;
q.push();
while (q.size()) {//当队列不空
int t = q.front();//取得队头
q.pop();
for (int i = h[t]; i != -; i = ne[i]) {
int j = e[i];//j扩展
if (d[j] == -) {//如果没有被遍历过
d[j] = d[t] + ;//扩展
q.push(j);//插入
}
}
}
return d[n];
}
int main() {
scanf("%d%d", &n, &m);
memset(h, -, sizeof h);
for (int i = ; i < m; i ++ ) {
int a, b;
scanf("%d%d", &a, &b);
add(a, b);
}
cout << bfs() << endl;
return ;
}
模拟队列
#include<bits/stdc++.h>
using namespace std ;
const int N=;
int n,m;
int h[N],e[N],ne[N],idx;
int d[N],q[N];
void add(int a,int b)
{
e[idx]=b;
ne[idx]=h[a];
h[a]=idx++;
}
int bfs()
{
int hh=,tt=;
q[]=;
memset(d,-,sizeof d);
d[]=;
while(hh<=tt)//当队列不空
{
int t=q[hh++];//取队头
for(int i=h[t];i!=-;i=ne[i])//扩展
{
int j=e[i];
if(d[j]==-)
{
d[j]=d[t]+;
q[++tt]=j;
}
}
}
return d[n];
}
int main()
{
cin>>n>>m;
memset(h,-,sizeof h);
for(int i=;i<m;i++)
{
int a,b;
cin>>a>>b;
add(a,b);
}
cout<<bfs()<<endl;
}
最新文章
- angularJS(2)
- Mac下安装LNMP(Nginx+PHP5.6)环境
- mono+jexus 验证码不显示:System.Drawing
- Which Python memory profiler is recommended
- POJ2299Ultra-QuickSort (线段树和归并排序的解法)
- HBase的Shell操作
- 使用Spring Profile和Mybatis进行多个数据源(H2和Mysql)的切换
- BZOJ 2442: [Usaco2011 Open]修剪草坪
- Creating a Navigation Drawer 创建一个导航侧边栏
- new Date()在IE,谷歌,火狐上的一些注意项
- 浙江大学PAT考试1069~1072(2013-11-2)
- React使用小结
- mySQL、mariaDB、noSQL、SQL server、redis之间是什么关系?
- Linux 中磁盘阵列RAID10配置
- 滴水穿石-01JAVA和C#的区别
- Unity容器中AOP应用示例程序
- CentOS配置多公网
- ueditor 使用
- Dom捕捉事件和冒泡事件-原理与demo测试
- BIOS备忘录之通过Windbg来追踪ASL code的运行