UESTC - 1147 求最短路方案数
这道题很是说明了记忆化搜索的重要性
瞎bfs递推半天发现没卵用(也许是姿势不对,但我认为树形或图形dfs明显好写并且很好正确地递推)
参考了别人的写法,总感觉自己的实现能力太弱了
还有题目是1e9+9,送了3WA(一眼1e9+7hhhhh)
/*H E A D*/
int to[maxn<<1],nxt[maxn<<1],cost[maxn<<1],head[maxn],tot;
void init(){
memset(head,-1,sizeof head);
tot=0;
}
void add(int u,int v,int w){
to[tot]=v;cost[tot]=w;nxt[tot]=head[u];head[u]=tot++;
swap(u,v);
to[tot]=v;cost[tot]=w;nxt[tot]=head[u];head[u]=tot++;
}
int dp[maxn];
int dis[maxn];
int n,m;
typedef pair<int,int> P;
void dijkstra(int s){
memset(dis,oo,sizeof dis);
priority_queue<P,vector<P>,greater<P> > que;
que.push(P(s,0));
dis[s]=0; dp[s]=1;
while(!que.empty()){
P p=que.top(); que.pop();
int u=p.first;
if(dis[u]<p.second)continue;
erep(i,u){
int v=to[i],w=cost[i];
if(dis[v]>dis[u]+w){
dis[v]=dis[u]+w;
que.push(P(v,dis[v]));
}
}
}
}
bool vis[maxn];
bool findzero(int u){
if(u==1)return 0;
bool flag=0;
erep(i,u){
int v=to[i],w=cost[i];
if(!vis[i]&&dis[u]==dis[v]+w){
vis[i]=vis[i^1]=1;
if(w==0) return 1;
if(findzero(v)) return 1;
}
}
return 0;
}
int DP(int u){
if(~dp[u]) return dp[u];
dp[u]=0;
erep(i,u){
int v=to[i],w=cost[i];
if(!vis[i]&&dis[u]==dis[v]+w){
vis[i]=1;
vis[i^1]=1;
dp[u]=(1ll*dp[u]+DP(v))%mod;
}
}
return dp[u];
}
int main(){
while(cin>>n>>m){
init();
rep(i,1,m){
int u=read();
int v=read();
int w=read();
add(u,v,w);
}
dijkstra(1);
memset(vis,0,sizeof vis);
bool flag=findzero(n);
if(flag) println(-1);
else{
memset(dp,-1,sizeof dp);
memset(vis,0,sizeof vis);
dp[1]=1;
println(DP(n));
}
}
return 0;
}
一组测试用数据
4 5
1 2 2
1 3 1
2 3 1
2 4 1
3 4 2
ans:3
顺便挂一下看着不错的写法:http://blog.csdn.net/code12hour/article/details/52081457
UESTC - 1147 求最短路方案数的更多相关文章
- HDU 1688 Sightseeing&HDU 3191 How Many Paths Are There(Dijkstra变形求次短路条数)
Sightseeing Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tota ...
- Codeforces 509F Progress Monitoring:区间dp【根据遍历顺序求树的方案数】
题目链接:http://codeforces.com/problemset/problem/509/F 题意: 告诉你遍历一棵树的方法,以及遍历节点的顺序a[i],长度为n. 问你这棵树有多少种可能的 ...
- P1466 集合 Subset Sums(01背包求填充方案数)
题目链接:https://www.luogu.org/problem/show?pid=1466 题目大意:对于从1到N (1 <= N <= 39) 的连续整数集合,能划分成两个子集合, ...
- caioj 1412 动态规划3:a+b问题(完全背包方案数)
每个素数就是一个物品,然后就相当于求完全背包方案数 把max改成+就好了. #include<cstdio> #include<vector> #include<cstr ...
- HDU 3416 Marriage Match IV (求最短路的条数,最大流)
Marriage Match IV 题目链接: http://acm.hust.edu.cn/vjudge/contest/122685#problem/Q Description Do not si ...
- poj 3734 方块涂色 求红色 绿色方块都为偶数的方案数 (矩阵快速幂)
N个方块排成一列 用红,蓝,绿,黄4种颜色去涂色,求红色方块 和绿色方块个数同时为偶数的 方案数 对10007取余 Sample Input 212Sample Output 2//(蓝,黄)6//( ...
- P1474 货币系统 Money Systems(完全背包求填充方案数)
题目链接:https://www.luogu.org/problemnew/show/1474 题目大意:有V种货币,求用V种货币凑出面值N有多少种方案. 解题思路:就是完全背包问题,只是将求最大价值 ...
- poj3254 Corn Fields 利用状态压缩求方案数;
Corn Fields 2015-11-25 13:42:33 Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 10658 ...
- CF 149D Coloring Brackets(区间DP,好题,给配对的括号上色,求上色方案数,限制条件多,dp四维)
1.http://codeforces.com/problemset/problem/149/D 2.题目大意 给一个给定括号序列,给该括号上色,上色有三个要求 1.只有三种上色方案,不上色,上红色, ...
随机推荐
- xamarin.droid自己的示例工程有些都装不上模拟器,是因为它的architectures选项没设对
也许是版本更迭导致的,有些老工程的architectures不对,如果x86不勾的话,是不能在genymotion的模拟器上跑的.
- Django--model模型绑定_数据库操作
1.创建model类 app01/models.py 1 2 3 4 5 6 7 from django.db import models # Create your models here. c ...
- TabbedPane标签美化式样自定义
JTabbedPane标签美化式样自定义 摘自:https://blog.csdn.net/yuanzihui/article/details/43936795 通过继承BasicTabbedPane ...
- Oracle——创建和管理表
一.常见的数据库对象 对象 描述 表 基本的数据存储集合,由行和列组成 视图 从表中抽出的逻辑上相关的数据集合 序列 提供有规律的数值 索引 提高查询的效率 同以词 给对象起别名 二.Oracle 数 ...
- Maven——依赖
一.依赖的范围 依赖的范围有几个可选值,我们用得到的是:compile.test.provided 三个. [1]从项目结构角度理解 compile 和 test 的区别 [2]从开发和运行这两个不同 ...
- [GO]切片和底层数组的关系
package main import "fmt" func main() { a := [], , , , , , , , , } s1 := a[:] s1[] = fmt.P ...
- UltraEdit 回车符替换空格
查找和替换 输入 ^r^n 替换为:(空格)
- IIS将http强转为https(重定向和重写)
最近接到一个需求,客户希望无论是http还是https请求都可以访问,并且http能转换成https.研究了一圈发现iis的重定向和重写都可以实现http强转https,记录一下. 用到的东东: In ...
- SourceTree使用
SourceTree的基本使用 1. SourceTree是什么 拥有可视化界面的项目版本控制软件,适用于git项目管理 window.mac可用 2. 获取项目代码 1. 点击克隆/新建 2. ...
- git中文乱码问题
控制台中输入:git config --global core.quotepath false