题目链接: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. Django框架之ORM对表结构操作

    ORM的优点:(1)简单,不用自己写SQL语句 (2)开发效率高 ORM的缺点:对于不同的人写的代码,执行效率有差别 ORM的对应关系: 类  ---------->  数据表 对象------ ...

  2. Linux : file命令

    file xxx file命令用来探测给定文件的类型.file命令对文件的检查分为文件系统.魔法幻数检查和语言检查3个过程 命令选项: -b:列出辨识结果时,不显示文件名称: -c:详细显示指令执行过 ...

  3. springboot2.x整合redis

    pom文件 <!--springboot中的redis依赖--> <dependency> <groupId>org.springframework.boot< ...

  4. QAction菜单行为

    /*File*/ QAction* close_action_; /*File*/ QAction* close_action_;

  5. Git基本指令

    Git学习笔记 git //检查git是否安装 sudo apt-get install git git config --global user.name "dzq" git c ...

  6. Invalid or unexpected token:数据格式错误

    一个查询页面突然出现如下这个错误: Uncaught SyntaxError: Invalid or unexpected token, 翻译成中文是: 捕获的查询无效或意外的标记. 既然代码逻辑没问 ...

  7. 操作系统OS - fork bomb(Windows)

    1. Type %0|%0 2. Save the file to your desktop as anything.bat

  8. 了解 C++

    C++的历史 C++由C语言发展演变而来,最初被称为"带类的C" 1983年正式取名为C++ 1998年11月被国籍标准化组织(ISO)批准为国际标准 2003年10月15日发布了 ...

  9. 【转】bug management process

    What is Bug? A bug is the consequence/outcome of a coding fault What is Defect? A defect is a variat ...

  10. 吴裕雄--天生自然PythonDjangoWeb企业开发:解决Pythonno module named "XX"问题

    在项目中加入 sys.path.append('你的django项目路径') sys.path.append('python的site-packages路径')