[SDOI2010] 魔法猪学院
Description
给定e和边权,求有多少条不同的道路能从1到n使得边权之和的和小于e
Solution
A*裸题 娘的要是SPFA再把dis写成to就剁手
// By YoungNeal
#include<queue>
#include<cstdio>
#include<cstring>
#define int long long
using namespace std;
double e;
int ans,INF;
];
];
];
int n,m,cnt1,cnt2;
],head2[];
struct Edge1{
int to,nxt;
double dis;
}edge1[];
struct Edge2{
int to,nxt;
double dis;
}edge2[];
void add1(int x,int y,double z){
edge1[++cnt1].to=y;
edge1[cnt1].dis=z;
edge1[cnt1].nxt=head1[x];
head1[x]=cnt1;
}
void add2(int x,int y,double z){
edge2[++cnt2].to=y;
edge2[cnt2].dis=z;
edge2[cnt2].nxt=head2[x];
head2[x]=cnt2;
}
struct Node{
int now;
double f,dis;
friend bool operator<(Node a,Node b){
return a.dis+a.f>b.dis+b.f;
}
};
queue<int> q;
priority_queue<Node> pq;
void spfa(int s){
dis[s]=;
q.push(s);
while(q.size()){
int u=q.front();q.pop();
b[u]=;
for(int i=head2[u];i;i=edge2[i].nxt){
int to=edge2[i].to;
if(dis[to]>dis[u]+edge2[i].dis){
dis[to]=dis[u]+edge2[i].dis;
if(!b[to]){
q.push(to);
b[to]=;
}
}
}
}
}
signed main(){
scanf("%lld%lld%lf",&n,&m,&e);
;i<=n;i++) dis[i]=;
;i<=m;i++){
int x,t;double q;
scanf("%lld%lld%lf",&x,&t,&q);
add1(x,t,q);add2(t,x,q);
}
spfa(n);
INF=e/dis[];
Node start;
start.now=,start.f=dis[],start.dis=;
pq.push(start);
while(pq.size()){
Node now=pq.top();pq.pop();
if(now.now==n){
e-=now.dis;
){
printf("%lld",ans);
;
}
ans++;
continue;
}
for(int i=head1[now.now];i;i=edge1[i].nxt){
Node nxt;
nxt.now=edge1[i].to;
nxt.dis=now.dis+edge1[i].dis;
nxt.f=dis[nxt.now];
pq.push(nxt);
}
}
}
[SDOI2010] 魔法猪学院的更多相关文章
- Bzoj 1975: [Sdoi2010]魔法猪学院 dijkstra,堆,A*,K短路
1975: [Sdoi2010]魔法猪学院 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 1357 Solved: 446[Submit][Statu ...
- bzoj 1975: [Sdoi2010]魔法猪学院 [k短路]
1975: [Sdoi2010]魔法猪学院 裸题... 被double坑死了 #include <iostream> #include <cstdio> #include &l ...
- BZOJ_1975_[Sdoi2010]魔法猪学院_A*
BZOJ_1975_[Sdoi2010]魔法猪学院_A* Description iPig在假期来到了传说中的魔法猪学院,开始为期两个月的魔法猪训练.经过了一周理论知识和一周基本魔法的学习之后,iPi ...
- K短路 (A*算法) [Usaco2008 Mar]牛跑步&[Sdoi2010]魔法猪学院
A*属于搜索的一种,启发式搜索,即:每次搜索时加一个估价函数 这个算法可以用来解决K短路问题,常用的估价函数是:已经走过的距离+期望上最短的距离 通常和Dijkstra一起解决K短路 BZOJ1598 ...
- bzoj 1975 [Sdoi2010]魔法猪学院
1975: [Sdoi2010]魔法猪学院 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 1758 Solved: 557[Submit][Statu ...
- P2483 [SDOI2010]魔法猪学院
P2483 [SDOI2010]魔法猪学院 摘要 --> 题目描述 iPig在假期来到了传说中的魔法猪学院,开始为期两个月的魔法猪训练.经过了一周理论知识和一周基本魔法的学习之后,iPig对猪世 ...
- [BZOJ1975][SDOI2010]魔法猪学院(k短路,A*)
1975: [Sdoi2010]魔法猪学院 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 2748 Solved: 883[Submit][Statu ...
- 【BZOJ1975】[Sdoi2010]魔法猪学院 A*
[BZOJ1975][Sdoi2010]魔法猪学院 Description iPig在假期来到了传说中的魔法猪学院,开始为期两个月的魔法猪训练.经过了一周理论知识和一周基本魔法的学习之后,iPig对猪 ...
- bzoj1975: [Sdoi2010]魔法猪学院【k短路&A*算法】
1975: [Sdoi2010]魔法猪学院 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 2446 Solved: 770[Submit][Statu ...
- [SDOI2010]魔法猪学院(A*,最短路)
[SDOI2010]魔法猪学院(luogu) Description 题目描述 iPig在假期来到了传说中的魔法猪学院,开始为期两个月的魔法猪训练.经过了一周理论知识和一周基本魔法的学习之后,iPig ...
随机推荐
- DTCMS插件的制作实例电子资源管理(四)URL重写
总目录 插件目录结构(一) Admin后台页面编写(二) 前台模板页编写(三) URL重写(四) 本实例旨在以一个实际的项目中的例子来介绍如何在dtcms中制作插件,本系列文章非入门教程,部分逻辑实现 ...
- Git 版本退回commit
有的时候错误提交了commit,需要版本退回. 先用git log查看一下节点版本号commit_id $ git log 再用git reset退回 $ git reset -soft commit ...
- Jpa中设置OneToMany插入报异常解决办法
在Jpa中如果设置@OneToMany,但使用的时候,如果没有赋值,会报异常出现,这时只需要实例化一个空数组即可, 但类型一定要对应: 实例如下: newField.setxxxxxList(new ...
- FFMpeg.H264解码win开发环境搭建
开发环境: vc6.0 + sp5 + vcpp5,注意vcpp5在vc6+sp6上会安装失败. 源码: ff_264_dec_vc,可用vc进行编译调试,但编译环境限定如上. 声明:该工程是ffmp ...
- 笔记+R︱风控模型中变量粗筛(随机森林party包)+细筛(woe包)
每每以为攀得众山小,可.每每又切实来到起点,大牛们,缓缓脚步来俺笔记葩分享一下吧,please~ --------------------------- 本内容来源于CDA-DSC课程内容,原内容为& ...
- Linux 的进程状态
(1)运行:当一个进程在处理机上运行时,则称该进程处于运行状态.处于此状态的进程的数目小于等于处理器的数目,对于单处理机系统,处于运行状态的进程只有一个.在没有其他进程可以执行时(如所有进程都在阻塞状 ...
- 图像处理------快速均值模糊(Box Blur)
图像模糊的本质, 从数字信号处理的角度看,图像模糊就要压制高频信号保留低频信号, 压制高频的信号的一个可选择的方法就是卷积滤波.选择一个低频滤波器,对图像上的 每个像素实现低频滤波,这样整体效果就是一 ...
- Error Code: 1175. You are using safe update mode and you tried to update a table without a WHERE
1 错误描述 19:15:34 call sp_store_insert(90) Error Code: 1175. You are using safe update mode and you tr ...
- 序列化Json格式
Json = JsonUtil.Serialize(new { code = 1, msg = "文件删除成功" }); public class JsonUtil { ...
- directX--关于CSource和CSourceStream (谁调用了fillbuffer)
CSourceStream类,是CSource类的OutputPin[source.h/source.cpp]派生自CAMThread和CBaseOutputPinl 成员变量: CS ...