题目链接 hdu6331

自我吐槽,这场多校大失败,开局签到因输入输出格式写错,wa了3发。队友C题wa了1个小时,还硬说自己写的没错,结果我随便造了个小数据,他都没跑对。然后跑对了后又进入了无限的卡常之中,幸好最后卡过去了。

G题我头铁写了个单侧凸壳,不对输入数据判重,而是在加入凸壳时判断,结果wa到比赛结束,进而导致I没时间写。M题开局看错题意直接丢了。最后从30多名掉到了150。这大概就是菜得安详吧 ̄ω ̄=

题意

给定n个点m条有向边,q次查询,每次查询问走至少k条边的,s到t的最短路径的长度,边可以重复走。

q=100000,n=50,m<=10000,k<=10000..

这题用矩阵快速幂啥的复杂度爆炸

细节

1.首先最基本的,要先对边去重留下最短边。

2.这里有个细节要注意一下,在某些情况下 s 到t距离,只有在走过的边数达到某个周期后才有解。

比如n个点组成一条有向环,则1到2距离只有在走过数边数k=1,n+1,2n+1  。周期也就是环的长度。

所以查询k时,答案的路径边数范围会在k到n+k之间。

3.任意两点的最短距离的边数小于n

预处理

首先预处理两个数组。g[k][s][t] 代表恰好走k条边后s到t的最短路径。

k=1,2,……10000.

这个用Floyd跑全部数据复杂度要k*n*n*n=12.5亿=GG。  这显然是不行的,所以只能分块,我取块长为100,即只让k=1,2,3,……100。但相邻二维数组之间间隔100条边。则复杂降低至1250万。

接着就是怎么处理块内了。

dis[k][s][t] 代表走大于等于k条边后s到t的最短路径。

k=1,2,……100 。

这个处理方式时先用floyd跑到k=200, 再逆向for 令dis[k][s][t]=min(dis[k][s][t],dis[k+1][s][t])这样就能保证在k=1,2,3……100时答案是正确的。

因为大于等于k的最坏情况,就是从s到达了点z,接着还要跑(z,t)之间的最短路才能到达t. 而最短路D的边数最多就n-1。 其实更新n项后就一定就正确了。所以溢出100项,只是写的顺手。

查询

对于k<=100的查询我们可以直接用dis数组回答复杂度O(1)

对于k>100的查询,令 k=q*100+r   其中1<=r<=100

则答案就是min(g[q][s][z]+dis[r][z][t])   。其中z是我们枚举的中间点。 这样就能保证查询到的答案是大于等于k的,且答案是正确的。单次查询复杂度O(n)

AC代码

 #include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<algorithm>
using namespace std;
int dis[][][];
int g[][][];
int INF=1e9,n;
int get(int s,int t,int k)
{
if(k<=)
{
return dis[k][s][t];
}
else
{
register int i,q,r,ans=INF; q=(k-)/;
r=k-*q;
//printf("%d %d \n",q,r);
for(i=; i<=n; i++)
{
ans=min(ans,dis[r][s][i]+g[q][i][t]);
}
return ans;
}
}
int main()
{
int m,t,x,y,w,q,ans;
register int i,j,k,l;
scanf("%d",&t);
while(t--)
{
scanf("%d%d",&n,&m);
memset(dis,,sizeof(dis));
memset(g,,sizeof(g));
INF=dis[][][];
// printf("%d\n",INF);
for(i=; i<=n; i++)
{
for(j=; j<=n; j++)
{
dis[][i][j]=INF;
}
}
while(m--) {
scanf("%d%d%d",&x,&y,&w);
dis[][x][y]=min(dis[][x][y],w);
}
for(i=; i<=; i++)
{
for(j=; j<=n; j++)
{
for(k=; k<=n; k++)
{
for(l=; l<=n; l++)
{
dis[i][j][k]=min( dis[i][j][k],dis[i-][j][l]+dis[][l][k]);
}
}
}
}
for(i=; i<=n; i++)
{
for(j=; j<=n; j++)
{
g[][i][j]=dis[][i][j];
}
}
for(i=; i<=; i++)
{
for(j=; j<=n; j++)
{
for(k=; k<=n; k++)
{
for(l=; l<=n; l++)
{
g[i][j][k]=min( g[i][j][k],g[i-][j][l]+g[][l][k]);
}
}
}
}
for(i=; i>=; i--)
{
for(j=; j<=n; j++)
{
for(k=; k<=n; k++)
{
dis[i][j][k]=min( dis[i][j][k],dis[i+][j][k]);
}
}
}
scanf("%d",&q);
while(q--)
{
scanf("%d%d%d",&x,&y,&k);
ans=get(x,y,k);
if(ans<=INF/)
{
printf("%d\n",ans);
}
else
{
puts("-1");
}
}
} return ;
}

HDU6331

话说我写的这么暴力,在ac代码里居然不算很慢的︿( ̄︶ ̄)︿

2018多校第三场 hdu6331 M :Walking Plan的更多相关文章

  1. 2018 HDU多校第三场赛后补题

    2018 HDU多校第三场赛后补题 从易到难来写吧,其中题意有些直接摘了Claris的,数据范围是就不标了. 如果需要可以去hdu题库里找.题号是6319 - 6331. L. Visual Cube ...

  2. 牛客多校第三场 F Planting Trees

    牛客多校第三场 F Planting Trees 题意: 求矩阵内最大值减最小值大于k的最大子矩阵的面积 题解: 矩阵压缩的技巧 因为对于我们有用的信息只有这个矩阵内的最大值和最小值 所以我们可以将一 ...

  3. 牛客多校第三场 G Removing Stones(分治+线段树)

    牛客多校第三场 G Removing Stones(分治+线段树) 题意: 给你n个数,问你有多少个长度不小于2的连续子序列,使得其中最大元素不大于所有元素和的一半 题解: 分治+线段树 线段树维护最 ...

  4. 2019 牛客暑期多校 第三场 F Planting Trees (单调队列+尺取)

    题目:https://ac.nowcoder.com/acm/contest/883/F 题意:求一个矩阵最大面积,这个矩阵的要求是矩阵内最小值与最大值差值<=m 思路:首先我们仔细观察范围,我 ...

  5. 2018 Multi-University Training Contest 3 杭电多校第三场

    躺了几天 终于记得来填坑了 1001 Ascending Rating   (hdoj 6319) 链接:http://acm.hdu.edu.cn/showproblem.php?pid=6319 ...

  6. 2018年多校第三场第一题 A. Ascending Rating hdu6319

    比赛地址:http://acm.hdu.edu.cn/contests/contest_show.php?cid=804 题目编号:第一题 A. Ascending Rating  hdu6319 题 ...

  7. 2018牛客多校第三场 C.Shuffle Cards

    题意: 给出一段序列,每次将从第p个数开始的s个数移到最前面.求最终的序列是什么. 题解: Splay翻转模板题.存下板子. #include <bits/stdc++.h> using ...

  8. 2018杭电多校第三场1003(状态压缩DP)

    #include<bits/stdc++.h>using namespace std;const int mod =1e9+7;int dp[1<<10];int cnt[1& ...

  9. hdu-4893-Wow! Such Sequence!-线段树【2014多校第三场-J】

    题意:一个初始为0的数组,支持三种操作:1.向第k个数添加d,(|d| < 2^31);2.把[l, r]区间内的数字都换成与它最相近的Fibonacci数;3.询问[l, r]区间的和. 思路 ...

随机推荐

  1. 【Kaggle】泰坦尼克号

    引言 Kaggle官方网站 这是泰坦尼克号事件的基本介绍: 我们需要做的就是通过给出的数据集,通过对特征值的分析以及运用机器学习模型,分析什么样的人最可能存活,并给出对测试集合的预测. 对于Kaggl ...

  2. stdio中牛逼的写法

    用空间换时间的典型 /* * NOTE! This ctype does not handle EOF like the standard C * library is required to. */ ...

  3. 1、spring boot入门

    1.Spring Boot 简介 简化Spring应用开发的一个框架: 整个Spring技术栈的一个大整合: J2EE开发的一站式解决方案: 2.微服务 2014,martin fowler 微服务: ...

  4. POJ-3126 BFS,埃式筛选及黑科技

    题目大意:给定两个四位素数a  b,要求把a变换到b,变换的过程要保证  每次变换出来的数都是一个 四位素数,而且当前这步的变换所得的素数  与  前一步得到的素数  只能有一个位不同,而且每步得到的 ...

  5. 修改 cmd 字体为 Consolas

    windows 下的 cmd 窗口默认的字体有点难看,长时间使用操作 node.js 有点小疲劳,可以修改注册表替换字体为 Consolas,并且可以全屏 cmd 窗口,代码如下: Windows R ...

  6. TouTiao开源项目 分析笔记7 加载数据的过程

    1.以新闻页中的段子数据显示为例 1.1.首先执行InitApp==>SplashActivity. 因为在AndroidManifest.xml中定义了一个<intent-filter& ...

  7. 有关ViewPager的使用及解决Android下ViewPager和PagerAdapter中调用notifyDataSetChanged失效的问题

    ViewPager是android-support-v4.jar包中的一个系统控件,继承自ViewGroup,专门用以实现左右滑动切换View的效果,使用时需要首先在Project->prope ...

  8. 关于safaire下hash前面需要加/(正斜杠)

    就是我们1.1框架是根据hash跳转的,今天我2.0跳转到1.1,pc一直测下来都是好的, 然后发现手机上一直跳转有问题,然后排查了半小时左右才发现  hash前面需要加/ 分割. 例如:http:/ ...

  9. 服务过美国总统竞选的非传统投票UI [解析及DEMO]

    上篇文章和大家介绍了需求情况和难点分析,大家可以看这个链接了解详细    服务过美国总统竞选的非传统投票UI      =================正文开始=================== ...

  10. cloud-utils

    官方下载:https://launchpad.net/cloud-utils rpm包下载地址:http://rpmfind.net/linux/rpm2html/search.php?query=c ...