BZOJ1975 SDOI2010魔法猪学院
就是个A*,具体原理可以参考VANE的博文。
正解要手写堆,会被卡常,也许哪天我筋搭错了写一回吧。
#include<bits/stdc++.h>
#define r register
using namespace std;
const int N=,eps=1e-,M=;
int head[N],cnt=-,sum,n,m,to[M],nex[M];
double d[N],E,ww[M];bool v[N];
inline void add(int x,int y,double w)
{
to[++cnt]=y;ww[cnt]=w;
nex[cnt]=head[x];head[x]=cnt;
to[++cnt]=x;ww[cnt]=w;
nex[cnt]=head[y];head[y]=cnt;
}
struct data{
int u;double g,h;
bool operator<(const data &b)const{
return g==b.g?h>b.h:g>b.g;
}
}t;
inline int read()
{
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<='')x=x*+ch-'',ch=getchar();
return x*f;
}
void spfa()
{
queue<int>Q;
Q.push(n);
memset(d,,sizeof(d));
d[n]=;v[n]=;
while(!Q.empty())
{
int x=Q.front();Q.pop();v[x]=;
for(r int i=head[x];i!=-;i=nex[i])
{
if(i&==)continue;
int y=to[i];
if(d[y]<=d[x]+ww[i])continue;
d[y]=d[x]+ww[i];
if(!v[y])
{
v[y]=;Q.push(y);
}
}
}
return;
}
int arr[N];
void work()
{
priority_queue<data>Q;
t.u=;t.h=;t.g=t.h+d[];
Q.push(t);int K=E/d[];
while(!Q.empty()&&E+eps>)
{
data x=Q.top();Q.pop();
if(x.g>E)break;
arr[x.u]++;
if(x.u==n)
{
sum++;E-=x.g;continue;
}
if(arr[x.u]>K)break;
for(r int i=head[x.u];i!=-;i=nex[i])
{
if(i&)continue;
data y;y.u=to[i];y.h=x.h+ww[i];y.g=y.h+d[y.u];
if(y.g>E)continue;
Q.push(y);
}
}
printf("%d\n",sum);
return;
}
int main()
{
n=read();m=read();
scanf("%lf",&E);
int x,y;double w;
memset(head,-,sizeof(head));
for(r int i=;i<=m;++i)
{
x=read();y=read();
scanf("%lf",&w);
add(x,y,w);
}
spfa();
work();
return ;
}
BZOJ1975 SDOI2010魔法猪学院的更多相关文章
- [BZOJ1975][SDOI2010]魔法猪学院(k短路,A*)
1975: [Sdoi2010]魔法猪学院 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 2748 Solved: 883[Submit][Statu ...
- bzoj1975: [Sdoi2010]魔法猪学院【k短路&A*算法】
1975: [Sdoi2010]魔法猪学院 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 2446 Solved: 770[Submit][Statu ...
- BZOJ1975 [Sdoi2010]魔法猪学院
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/ ...
- BZOJ1975[Sdoi2010]魔法猪学院——可持久化可并堆+最短路树
题目描述 iPig在假期来到了传说中的魔法猪学院,开始为期两个月的魔法猪训练.经过了一周理论知识和一周基本魔法的学习之后,iPig对猪世界的世界本原有了很多的了解:众所周知,世界是由元素构成的:元素与 ...
- 洛谷P2483 Bzoj1975 [SDOI2010]魔法猪学院
题目描述 iPig在假期来到了传说中的魔法猪学院,开始为期两个月的魔法猪训练.经过了一周理论知识和一周基本魔法的学习之后,iPig对猪世界的世界本原有了很多的了解:众所周知,世界是由元素构成的:元素与 ...
- BZOJ1975 [Sdoi2010]魔法猪学院 k短路
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1975 题意概括 给出一个无向图,让你走不同的路径,从1到n,路径长度之和不超过E,求最大路径条数. ...
- BZOJ1975 SDOI2010魔法猪学院(启发式搜索+最短路+堆)
对反图跑最短路求出每个点到终点的最短路径,令其为估价函数大力A*,第k次到达某个点即是找到了到达该点的非严格第k短路,因为估价函数总是不大于实际值.bzoj可能需要手写堆.正解是可持久化可并堆,至今是 ...
- 【k短路&A*算法】BZOJ1975: [Sdoi2010]魔法猪学院
Description 找出1~k短路的长度. Solution k短路的求解要用到A*算法 A*算法的启发式函数f(n)=g(n)+h(n) g(n)是状态空间中搜索到n所花的实际代价 h(n) ...
- 【BZOJ1975】[Sdoi2010]魔法猪学院 A*
[BZOJ1975][Sdoi2010]魔法猪学院 Description iPig在假期来到了传说中的魔法猪学院,开始为期两个月的魔法猪训练.经过了一周理论知识和一周基本魔法的学习之后,iPig对猪 ...
随机推荐
- powerdesigner怎么设置同时显示name和code
实现方法:Tools-Display Preference 从数据库里抽取了数据模型,为了理清思路,需要将name改为中文名称,但是pd自动将name填充为code,可以通过如下配置修改: 选择too ...
- iframe子夜页面调父页面的方法 取父页面的值
1.调父页面的方法的写法 window.parent.yincang();//yincang()是父页面的一个方法 2.取父页面的值的写法 window.parent.document.gettEle ...
- CodeForces - 1004C
Since Sonya is interested in robotics too, she decided to construct robots that will read and recogn ...
- 2、Web基本介绍及Html语法介绍
1.1 Web基本介绍 1.web就是world wide web的缩写.称之为全球广域网,俗称www.2.我们可以将web理解为就是当前的一种互联网.对于我们来说更多的就是网站服务.3.网站我们可以 ...
- android 图片旋转 移动 放大缩小
图片的变化主要是matrix的变化,对matrix不懂的可以先了解下matrxi. public class FunnyView extends View { /* * 手指按下时可能是移动 也可能是 ...
- linux内核sysfs详解【转】
转自:http://blog.csdn.net/skyflying2012/article/details/11783847 "sysfs is a ram-based filesystem ...
- 64_r2
ruby-gnomecanvas2-0.90.4-7.fc26.3.x86_64.rpm 13-Feb-2017 08:00 75794 ruby-gnomecanvas2-devel-0.90.4- ...
- java各种链路工具性能监控工具
Zipkin , Instana 和 Jaeger cat链路追踪系统 用于监控spring 的运行情况,比如内存,线程,池等宏观数据 spring boot admin java反编译 jar xv ...
- u-boot启动第二阶段以及界面命令分析
u-boot第一阶段完成了一些平台相关的硬件的配置,第一阶段所做的事情也是为第二阶段的准备,我们知道在第一阶段最后时搭建好C运行环境,之后调用了start_armboot(),那么很显然第二阶段从st ...
- 关于VS2010的一些操作
自动插入接口实现 1: class MyClass : IMyInterface 2: { 3: 4: } .csharpcode, .csharpcode pre { font-size: sm ...