题目链接:P1144 最短路计数

很简单的一道\(dfs\),然而我又跑了一遍\(dij\)和排序,时间复杂度是\(O(nlog n)\)

注意:\(1\).搜索时向\(dis[j]=dis[cur]-1\)的点\(j\)搜就好了;

\(2\).注意记录重边,而且我们存的无向图是两倍边,记得都加(\(233\))

\(3\).记得把所有不能更新的都更一遍,不要只更新最远点(就是记录一个\(deg[]\))

上代码:

\(Code\):

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<queue>
#define mod 100003
using namespace std;
struct node
{
int l,r;
}a[2000005];
bool cmp(node n,node m){if(n.l^m.l) return n.l<m.l;else return n.r<m.r;}
struct edge
{
int to,nxt,num;
}e[2000005<<1];
int head[1000005],cnt=0;
void add(int u,int v)
{
e[++cnt].to=v;
e[cnt].nxt=head[u];
e[cnt].num=1;
head[u]=cnt;
}
int dis[1000005],vis[1000005];
int o=0;
int f[1000005];
priority_queue<pair<int,int>,vector<pair<int,int> >,greater<pair<int,int> > >q;
void dij()
{
while(!q.empty())
{
int j=q.top().second;
q.pop();
if(vis[j]) continue;
vis[j]=1;
for(int i=head[j];i;i=e[i].nxt)
{
int k=e[i].to;
if(dis[k]>dis[j]+1)
{
dis[k]=dis[j]+1;
q.push(make_pair(dis[k],k));
}
}
}
}
int dp[1000005],deg[1000005];
int n,m,ll=-1,rr=-1,root=-1;
int dfs(int cur)
{
//if(deg[cur]<=1&&cur!=root) return dp[cur]=1;
if(dp[cur]) return dp[cur];
for(int i=head[cur];i;i=e[i].nxt)
{
int j=e[i].to;
if(dis[j]==dis[cur]-1) dp[cur]=(dp[cur]+e[i].num*dfs(j)%mod)%mod;
}
return dp[cur]%mod;
}
int main()
{
//freopen("data.in","r",stdin);
//freopen("baoli.out","w",stdout);
scanf("%d%d",&n,&m);
for(int i=1;i<=m;i++) scanf("%d%d",&a[i].l,&a[i].r);
sort(a+1,a+m+1,cmp);
for(int i=1;i<=m;i++)
{
if(a[i].l==ll&&a[i].r==rr)
{
e[cnt].num++;
e[cnt-1].num++;
continue;
}
else
{
ll=a[i].l,rr=a[i].r;
add(ll,rr);
add(rr,ll);
deg[ll]++,deg[rr]++;
}
}
for(int i=2;i<=n;i++) dis[i]=mod/10*mod;
q.push(make_pair(0,1));
//for(int i=1;i<=n;i++) if(dis[i]>dis[root]) root=i;
dij();
dp[1]=1;
for(int i=2;i<=n;i++) dp[i]=0;
for(int i=1;i<=n;i++) if(!dp[i]) dfs(i);
//dfs(root);
for(int i=1;i<=n;i++) printf("%d\n",dp[i]%mod);
}

解题报告:luogu P1144 最短路计数的更多相关文章

  1. Luogu P1144 最短路计数 【最短路】 By cellur925

    题目传送门 常规的最短路计数问题:注意有重边(重边不用理,看样例),自环(读入时过滤). 另外这个无向图没有权,其实可以直接bfs做,但考虑到以后带权的情况,按spfa走了. 水题被卡了三次(嘤嘤嘤 ...

  2. 【luogu P1144 最短路计数】 题解

    题目链接:https://www.luogu.org/problemnew/show/P1144 #include <iostream> #include <cstdio> # ...

  3. [Luogu P1144]最短路计数

    emmmm这个题看起来非常复杂,实际上仔细一分析发现到一个点最短路的个数就是所有前驱最短路个数之和.如果在图上表示也就是以1为根的bfs搜索树,一个点的最短路个数等于每一个能够向它扩展的所有点的最短路 ...

  4. 洛谷 P1144 最短路计数 解题报告

    P1144 最短路计数 题目描述 给出一个\(N\)个顶点\(M\)条边的无向无权图,顶点编号为\(1-N\).问从顶点1开始,到其他每个点的最短路有几条. 输入输出格式 输入格式: 第一行包含2个正 ...

  5. P1144 最短路计数

    P1144 最短路计数 题目描述 给出一个N个顶点M条边的无向无权图,顶点编号为1-N.问从顶点1开始,到其他每个点的最短路有几条. 输入输出格式 输入格式: 输入第一行包含2个正整数N,M,为图的顶 ...

  6. 洛谷——P1144 最短路计数

    P1144 最短路计数 题目描述 给出一个N个顶点M条边的无向无权图,顶点编号为1-N.问从顶点1开始,到其他每个点的最短路有几条. 输入输出格式 输入格式: 输入第一行包含2个正整数N,M,为图的顶 ...

  7. 洛谷 P1144 最短路计数 题解

    P1144 最短路计数 题目描述 给出一个\(N\)个顶点\(M\)条边的无向无权图,顶点编号为\(1-N\).问从顶点\(1\)开始,到其他每个点的最短路有几条. 输入格式 第一行包含\(2\)个正 ...

  8. 洛谷P1144 最短路计数 及其引申思考

    图论题目练得比较少,发一道spfa的板子题目- 题目:P1144 题目描述 给出一个N个顶点M条边的无向无权图,顶点编号为1-N.问从顶点1开始,到其他每个点的最短路有几条. 输入输出格式 输入格式: ...

  9. P1144 最短路计数 题解 最短路应用题

    题目链接:https://www.luogu.org/problem/P1144 其实这道题目是最短路的变形题,因为数据范围 \(N \le 10^6, M \le 2 \times 10^6\) , ...

随机推荐

  1. 理解CART决策树

    CART算法 原理 CART全称为Classification and Regression Tree. 回归树 相比ID3,CART遍历所有的特征和特征值,然后使用二元切分法划分数据子集,也就是每个 ...

  2. Golang核心编程

    源码地址: https://github.com/mikeygithub/GoCode 第1章 1Golang 的学习方向 Go 语言,我们可以简单的写成 Golang 1.2Golang 的应用领域 ...

  3. ubuntu---查看、安装、切换内核

    首先可以查看一下内核列表:sudo dpkg --get-selections | grep linux-image     查看Linux中安装了哪些内核: dpkg --get-selection ...

  4. 吴裕雄 python 神经网络——TensorFlow训练神经网络:卷积层、池化层样例

    import numpy as np import tensorflow as tf M = np.array([ [[1],[-1],[0]], [[-1],[2],[1]], [[0],[2],[ ...

  5. 临时解决执行 Composer Install 返回 Killed 的问题

    昨天在 Linux 服务器上部署 PHP 项目时遇到了一个问题,系统为 Centos 7 ,1 核 1G 的配置.通过 Git 拉取代码后,由于是基于 Laravel 框架的项目,所以需要使用 Com ...

  6. 免费的私人代码托管(bitbucket) 和 常用git指令

    转自 http://blog.csdn.net/nzing/article/details/24452475 今天想找个免费的私人代码托管平台,github,googlecode, SourceFor ...

  7. Rect Native 使用

    参见 Rect Native 中文官网. 依赖环境: Homebrew.npm.Node.js.Watchman(监测Bug和文件变化,触发指定操作).flow(JS静态类型检查仪,以方便找出代码中错 ...

  8. Tomcat 配置目录及文件说明!

    ==================================================================================

  9. jqGird错误“decimalSeparator”的解决办法

    在使用jqGrid的过程中,突然出现以下错误: jquery.jqGrid.js:15016 Uncaught TypeError: Cannot read property 'decimalSepa ...

  10. MyBatis映射器(转载)

    什么是MyBatis映射器? MyBatis框架包括两种类型的XML文件,一类是配置文件,即mybatis-config.xml,另外一类是映射文件,例如XXXMapper.xml等.在MyBatis ...