3482: [COCI2013]hiperprostor

Time Limit: 20 Sec  Memory Limit: 256 MB
Submit: 277  Solved: 81

Description

在遥远的未来,行星之间的食品运输将依靠单向的贸易路线。每条路径直接连接两个行星,且其运输时间是已知的
。贸易商协会打算利用一项最近发现的新技术——超空间旅行,以增加一些新的航线。通过超空间旅行的航线也是
单向的。由于该项技术仍处于试验阶段,超空间旅行的时间目前是未知的,但它不取决于行星之间的距离,所以每
个超空间旅行的路线将花费等量的时间。下图是三个相互联通的行星及其运输时间的例子。行星使用正整数标号,
超空间旅行时间记为“x”(图片对应第输入样例):过境的时间以天计,并且始终是一个正整数。贸易商协会希
望对引进新航线的后果进行分析:对于某两个行星A和B,他们想知道对于任意的x,从A到B的最短路径的总中转时
间的所有可能的值。例如,在上述情况中,从星球2到星球1的最短路径所需时间可以取值5(如果x≥5),4,3,2
,或1天(如果x<5)

Input

输入的第一行包含两个整数P和R,分别代表行星的数目和航线数量,1≤P≤500,0≤R≤10000。接下来的R条航线
路径包含两或三个整数:行星标号C和D(1≤C,D≤P,C≠D),和T,从C到D的旅行时间。对于传统的路径,T是一
个整数(1≤T≤1000000),超空间航线中,T是字符“x”。 可以存在多行有两个相同的行星。下面的行中包含的
整数Q(1≤Q≤10),表示查询的数量。以下Q行包含两个整数星球标号(A和B,A≠B),为贸易商协会的查询:“
从A到B的最短路径时间的可能值是什么?

Output

输出必须包含q行,每行??一个查询。每一行都必须包含两个整数:不同的可能值的数目和它们的总和。如果不同
的可能值的数目是无限的,该行只输出“inf”。如果没有从A到B的路径,不同的可能值的数目及它们的总和都是0

Sample Input

4 4
1 2 x
2 3 x
3 4 x
1 4 8
3
2 1
1 3
1 4

Sample Output

0 0
inf
3 17

HINT

2016.6.15新加数据一组,未重测

Source

【分析】

  f[i][j]表示走到i,走了j条x边,最短路。【好像spfa会被卡,我就打了dij

  【dij的比较没有打return 调了半天哭死。。。

  若f[i][j]全是INF 就是无解

  若f[i][0]是INF 就是无穷解

  然后其他的,得到i,f[i][ed],写成直线y=i*x+f[i][ed],维护一个凸包。

  他们中间点的个数和值是等差数列,直接求和。

 #include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<queue>
using namespace std;
#define Maxn 510
#define Maxm 10010
#define LL long long
#define INF 0x7fffffff int n,m; int read()
{
char ch;
while(!(((ch=getchar())>=''&&ch<='')||(ch=='x')));
if(ch=='x') return ;
int x=ch-'';
while(((ch=getchar())>='')&&(ch<='')) x=x*+ch-'';
return x;
} struct node
{
int x,y,next,c;
}t[Maxm*];
int len,first[Maxn]; void ins(int x,int y,int c)
{
t[++len].x=x;t[len].y=y;t[len].c=c;
t[len].next=first[x];first[x]=len;
} struct hp
{
int x,y,dis;
friend bool operator < (hp x,hp y)
{
return x.dis>y.dis;
}
}; int f[Maxn][Maxn];
priority_queue<hp> q;
void dij(int st)
{
hp nw;nw.dis=;nw.x=st;nw.y=;
q.push(nw);f[st][]=;
while(!q.empty())
{
nw=q.top();q.pop();
if(nw.dis>f[nw.x][nw.y]) continue;
int x=nw.x;
hp now;
for(int i=first[x];i;i=t[i].next)
{
int y=t[i].y;
if(t[i].c==)
{
if(nw.y==n) continue;
now.x=y;now.y=nw.y+;now.dis=nw.dis;
if(f[now.x][now.y]>f[nw.x][nw.y])
{
f[now.x][now.y]=f[nw.x][nw.y];
q.push(now);
}
}
else
{
now.x=y;now.y=nw.y;now.dis=f[nw.x][nw.y]+t[i].c;
if(f[now.x][now.y]>f[nw.x][nw.y]+t[i].c)
{
f[now.x][now.y]=f[nw.x][nw.y]+t[i].c;
q.push(now);
}
}
}
}
}
struct Line
{
double k,b;
Line() {}
Line(double nk,double nb) {k=nk;b=nb;}
}P[Maxn];int sl;double tt[Maxn]; double pt(double k1,double b1,double k2,double b2)
{
return (b2-b1)/(k1-k2);
} void get_ans()
{
int q=read();int cnt=;
while(q--)
{
int st=read(),ed=read();
for(int i=;i<=n;i++)
for(int j=;j<=n;j++) {f[i][j]=INF;}
dij(st);
bool pp=;
for(int i=;i<=n;i++) if(f[ed][i]!=INF) {pp=;break;}
if(!pp) {printf("0 0\n");continue;}
if(f[ed][]==INF) {printf("inf\n");continue;}
int num=;
LL sum=;sl=;
for(int i=n;i>=;i--)
{
if(f[ed][i]==INF) continue;
while(sl>=&&pt(P[sl].k,P[sl].b,i,f[ed][i])<=tt[sl]) sl--;
P[++sl]=Line(i,f[ed][i]);
if(sl>) tt[sl]=pt(P[sl-].k,P[sl-].b,P[sl].k,P[sl].b);
}
for(int i=;i<=sl-;i++)
{
int l=(int)tt[i]+,r=(int)tt[i+];
if(l<=r) sum+=(LL)(l*P[i].k+P[i].b+r*P[i].k+P[i].b)*(r-l+)/;
}
num=(int)tt[sl];
if(tt[sl]!=num||sl==) num++,sum+=f[ed][];
printf("%d %lld\n",num,sum);
}
} int main()
{
n=read();m=read();
len=;
memset(first,,sizeof(first));
for(int i=;i<=m;i++)
{
int x,y,c;
x=read();y=read();c=read();
ins(x,y,c);
}
get_ans();
return ;
}

【凸包和dij都好弱啊,膜了一下某大神代码。。】

2017-03-31 08:17:57

【BZOJ 3482】 3482: [COCI2013]hiperprostor (dij+凸包)的更多相关文章

  1. bzoj 1185 [HNOI2007]最小矩形覆盖 凸包+旋转卡壳

    题目大意 用最小矩形覆盖平面上所有的点 分析 有一结论:最小矩形中有一条边在凸包的边上,不然可以旋转一个角度让面积变小 简略证明 我们逆时针枚举一条边 用旋转卡壳维护此时最左,最右,最上的点 注意 注 ...

  2. BZOJ 1069 Luogu P4166 最大土地面积 (凸包)

    题目链接: (bzoj)https://www.lydsy.com/JudgeOnline/problem.php?id=1069 (luogu)https://www.luogu.org/probl ...

  3. 【BZOJ】1027: [JSOI2007]合金(凸包+floyd)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1027 题意:$n$种材料,$m$种需求.每种材料有三个属性,给出三个属性的含量(和为1),问能否通过 ...

  4. bzoj 1209: [HNOI2004]最佳包裹 三维凸包

    1209: [HNOI2004]最佳包裹 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 160  Solved: 58[Submit][Status] ...

  5. BZOJ 2300: [HAOI2011]防线修建( 动态凸包 )

    离线然后倒着做就变成了支持加点的动态凸包...用平衡树维护上凸壳...时间复杂度O(NlogN) --------------------------------------------------- ...

  6. BZOJ [HAOI2011]防线修建(动态凸包)

    听说有一种很高端的东西叫动态凸包维护dp就像学一下,不过介于本人还不会动态凸包就去学了下,还是挺神奇的说,维护上下凸包的写法虽然打得有点多不过也只是维护复制黏贴的事情而已罢了. 先说下动态凸包怎么写吧 ...

  7. BZOJ 3203 [SDOI2013]保护出题人 (凸包+三分)

    洛谷传送门 题目大意:太长略 每新加入一个僵尸,容易得到方程$ans[i]=max{\frac{sum_{i}-sum_{j-1}}{s_{i}+d(i-j)}}$ 即从头开始每一段僵尸都需要在规定距 ...

  8. BZOJ3482 : [COCI2013]hiperprostor

    对于每组询问,spfa求出f[i][j]表示从S出发,经过j条x边到达i的最短路. 若f[T][i]都为inf,则无解. 若f[T][0]为inf,则有无穷个解. 否则可以看作若干条直线,$O(n)$ ...

  9. bzoj 3203: [Sdoi2013]保护出题人 凸包

    题目大意: http://www.lydsy.com/JudgeOnline/problem.php?id=3203 题解 首先我们考虑对一大波僵尸来袭的情况进行分析 假设来袭的僵尸是\(\{ a_1 ...

随机推荐

  1. Spring容器简介

    Spring 是面向 Bean 的编程(BOP,Bean Oriented Programming),提供了 IOC 容器通过配置文件或者注解的方式来管理对象之间的依赖关系. 控制反转模式(也称作依赖 ...

  2. 【CF802C】 Heidi and Library (hard)(费用流)

    题目链接 感觉跟餐巾计划问题有点像.费用流. 决定每天买不买不太好搞,不如先把所有东西都买进来,再卖掉不必要的. 拆点,每个点拆成\(x,y\). 源点向每个点的\(x\)连费用为当天的价格,流量为1 ...

  3. Metasploit 一些重要模块使用介绍

    本文是"T00LS Metasploit(第一季)"的文档版,是个人在观看视频动手操作的一个记录,仅供学习.文中会介绍Metasploit的一些基本使用:端口扫描.smb扫描.服务 ...

  4. JavaScript 使用闭包保护变量 防止污染

    使用JavaScript编写插件或团队协作时,可使用闭包来解决此类以下两个问题: 1.定义过多全局变量,可能会造成全局变量命名冲突: 2.在插件内定义变量,需要保护该变量不被轻易修改: 优点:可以把局 ...

  5. python3爬虫.1.简单的网页爬虫

    此为记录下我自己的爬虫学习过程. 利用url包抓取网页 import urllib.request #url包 def main(): url = "http://www.douban.co ...

  6. 强连通图(最多加入几条边使得图仍为非强连通图)G - Strongly connected HDU - 4635

    题目链接:https://cn.vjudge.net/contest/67418#problem/G 具体思路:首先用tarjan缩点,这个时候就会有很多个缩点,然后再选取一个含有点数最少,并且当前这 ...

  7. Python基础之杂货铺

    字符串格式化 Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-310 ...

  8. fastJson去掉指定字段

    public static String filterFieldsJson(Object src, Class<?> clazz, String... args) { SimpleProp ...

  9. 4、GitLab 创建、删除、修改项目

    一.gitLab创建项目 1.创建用户组 2.填写组信息后单击“Create group” 其中:“Group path”将显示在git路径中 3.选择需要加入该组的“用户”和“角色”后点击“Add ...

  10. java图片转byte转string

    第一种:原始乱码: public static void main(String[] args) throws IOException { File imgFile = new File(" ...