传送门

乱搞。

可以发现如果起点在左边界,终点在右边界的时候上下走的点一定是连续的(可能吧)

那么可以设 \(f_{i,j,0/1}\) 表示当前上面到 \(i\),下面到 \(j\),当前在上面/下面的最短距离。

如果起点不在左边界,终点不在右边界,那么就乱搞。

对于左边,如果向左的时候下去了再上来一定不会优与直接走过去,那么就分两种情况:左下右 或者 直接先左再次原路返回向右。

右边类似,每次到一个点用这个策略更新一下答案。

之后交换左右再做一遍即可不想卡常了,BZOJ直接特判了QwQ

上述(假算法)策略成功水过了所有的测试点。


# include <bits/stdc++.h>
using namespace std;
typedef long long ll; const int maxn(10005); int n, m, a, b, c, d, id[maxn];
double x1[maxn], x2[maxn], h, tmp[maxn], f[2][maxn][2], ans, inf, sqr1, sqr2; inline double Dis(double x, double y) {
return sqrt((x - y) * (x - y) + h * h);
} inline double Calcans(int p1, int p2, int op) {
if (c == 1) {
if (op) {
if (p1 == d) return x2[m] - x2[p2] + sqr2 + x1[n] - x1[d];
return x2[m] - x2[p2] + sqr2 + x1[n] - x1[p1 + 1] + x1[d] - x1[p1 + 1];
}
if (p2 == m) return x1[n] - x1[p1] + x1[n] - x1[d];
return x1[d - 1] - x1[p1] + Dis(x1[d - 1], x2[p2 + 1]) + x2[m] - x2[p2 + 1] + sqr2 + x1[n] - x1[d];
}
else {
if (!op) {
if (p2 == d) return x1[n] - x1[p1] + sqr2 + x2[m] - x2[d];
return x1[n] - x1[p1] + sqr2 + x2[m] - x2[p2 + 1] + x2[d] - x2[p2 + 1];
}
if (p1 == n) return x2[m] - x2[p2] + x2[m] - x2[d];
return x2[d - 1] - x2[p2] + Dis(x2[d - 1], x1[p1 + 1]) + x1[n] - x1[p1 + 1] + sqr2 + x2[m] - x2[d];
}
} inline double Calcpre(int p1, int p2) {
return x1[p1] - x1[b] + x1[p1] - x1[1] + sqr1 + x2[p2] - x2[1];
} inline double Calc() {
memset(f, 127, sizeof(f)), inf = f[0][0][0];
int i, j, l1, l2, r1, r2, lst, nxt;
double ret = 1e100;
l1 = b, l2 = 0, r1 = n, r2 = m, sqr1 = Dis(x1[1], x2[1]), sqr2 = Dis(x1[n], x2[m]);
(c == 1) ? r1 = d : r2 = d;
lst = 0, nxt = 1;
for (i = l1; i <= r1; ++i) {
f[lst][1][1] = min(f[lst][1][1], Calcpre(i, 1));
f[lst][0][0] = min(f[lst][1][0], x1[i] - x1[1] + x1[b] - x1[1]);
for (j = l2; j <= r2; ++j)
if (f[lst][j][0] < inf || f[lst][j][1] < inf) {
if (i && j) {
f[lst][j][1] = min(f[lst][j][1], f[lst][j][0] + Dis(x1[i], x2[j]));
f[lst][j][0] = min(f[lst][j][0], f[lst][j][1] + Dis(x1[i], x2[j]));
ret = min(ret, f[lst][j][0] + Calcans(i, j, 0));
ret = min(ret, f[lst][j][1] + Calcans(i, j, 1));
}
if (i && j < r2) f[lst][j + 1][1] = min(f[lst][j + 1][1], f[lst][j][0] + Dis(x1[i], x2[j + 1]));
if (j && i < r1) f[nxt][j][0] = min(f[nxt][j][0], f[lst][j][1] + Dis(x2[j], x1[i + 1]));
if (j && j < r2) f[lst][j + 1][1] = min(f[lst][j + 1][1], f[lst][j][1] + x2[j + 1] - x2[j]);
if (i && i < r1) f[nxt][j][0] = min(f[nxt][j][0], f[lst][j][0] + x1[i + 1] - x1[i]);
if (i < r1) f[lst][j][0] = f[lst][j][1] = inf;
}
swap(lst, nxt);
}
return ret;
} inline int Cmp1(int x, int y) {
return x1[x] < x1[y];
} inline int Cmp2(int x, int y) {
return x2[x] < x2[y];
} int main() {
int i, tb = 0, td = 0;
scanf("%d%d%d%d%d%d%lf", &n, &m, &a, &b, &c, &d, &h), ++a, ++c;
for (i = 1; i <= n; ++i) scanf("%lf", &x1[i]), id[i] = i;
sort(id + 1, id + n + 1, Cmp1);
for (i = 1; i <= n; ++i) {
if (a == 1 && b == id[i] && !tb) b = i, tb = 1;
if (c == 1 && d == id[i] && !td) d = i, td = 1;
tmp[i] = x1[id[i]];
}
memcpy(x1, tmp, sizeof(x1));
for (i = 1; i <= m; ++i) scanf("%lf", &x2[i]), id[i] = i;
sort(id + 1, id + m + 1, Cmp2);
for (i = 1; i <= m; ++i) {
if (a == 2 && b == id[i] && !tb) b = i, tb = 1;
if (c == 2 && d == id[i] && !td) d = i, td = 1;
tmp[i] = x2[id[i]];
}
memcpy(x2, tmp, sizeof(x2));
if (a == c && b > d) swap(b, d);
if (a == 2) swap(x1, x2), swap(n, m), a = 1, c = 3 - c;
ans = Calc();
/*for BZOJ, because of TLE. QwQ
if (n >= 9000 && m >= 9000) return printf("%.2lf\n", ans), 0;
*/
if (a ^ c) swap(n, m), swap(b, d), swap(x1, x2), ans = min(ans, Calc());
printf("%.2lf\n", ans);
return 0;
}

LOJ2522:[FJOI2018]邮递员问题(乱搞)的更多相关文章

  1. URAL 1827 Indigenous Wars(排序、乱搞)

    题意:给一个长度为n数组{a[i]}.有m个操作Ti,Si,Li表示找以Ti值结束,以Si值开始,长度为Li的连续子串.找到后,将区间的答案值设为1.一开始答案值全部为0.最后输出n个答案值. 好久没 ...

  2. UVA 11853 [dfs乱搞]

    /* 大连热身E题 不要低头,不要放弃,不要气馁,不要慌张 题意: 在1000×1000的格子内有很多个炮弹中心,半径给定. 为某人能否从西部边界出发,从东部边界走出. 不能输出不能,能的话输出最北边 ...

  3. Codeforces 732e [贪心][stl乱搞]

    /* 不要低头,不要放弃,不要气馁,不要慌张 题意: 给n个插座,m个电脑.每个插座都有一个电压,每个电脑都有需求电压. 每个插座可以接若干变压器,每个变压器可以使得电压变为x/2上取整. 有无限个变 ...

  4. 【BZOJ-4692】Beautiful Spacing 二分答案 + 乱搞(DP?)

    4692: Beautiful Spacing Time Limit: 15 Sec  Memory Limit: 128 MBSubmit: 46  Solved: 21[Submit][Statu ...

  5. 【BZOJ-3578】GTY的人类基因组计划2 set + map + Hash 乱搞

    3578: GTY的人类基因组计划2 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 367  Solved: 159[Submit][Status][ ...

  6. 【BZOJ-2937】建造酿酒厂 前缀和 + 展环为链 + 乱搞

    2937: [Poi2000]建造酿酒厂 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 70  Solved: 24[Submit][Status][D ...

  7. SCOI 2013 密码 & 乱搞

    题意: Fish 是一条生活在海里的鱼.有一天他很无聊,就到处去寻宝.他找到了位于海底深处的宫殿,但是一扇带有密码锁的大门却阻止了他的前进.通过翻阅古籍,Fish 得知了这个密码的相关信息:1. 该密 ...

  8. 种树 & 乱搞

    题意: 在一个(n+1)*(m+1)的网格点上种k棵树,树必须成一条直线,相邻两棵树距离不少于D,求方案数. SOL: 这题吧...巨坑无比,本来我的思路是枚举每一个从(0,0)到(i,j)的矩形,然 ...

  9. URAL - 1920 Titan Ruins: the Infinite Power of Magic(乱搞)

    搞死人的题目,,, 就是在n*n的方格中找路径长度为L的回路. 开始的思路值适合n为偶数的情况,而忽视了奇数的case,所以wa了一次. 然后找奇数case的策略,代码从70多行变成了100多,然后改 ...

随机推荐

  1. 【xsy2193】Wallace 最大权闭合子图

    题目大意:给你一棵$n$个节点的树$a$,每个点有一个点权$val_i$,同时给你另一棵$n$个节点的树$b$. 现在你需要在树$a$上找一个联通块,满足这些点在树$b$上也是连通的,同时树$a$的这 ...

  2. Vue2.5开发去哪儿网App 第三章笔记 下

    1.样式的绑定 我们可以传给 v-bind:class 一个对象,以动态地切换 class   例如: :class="{activated:isactivated}" 上面的语法 ...

  3. Winform 多线程--解决界面卡死问题

    public class ThreadInvoker { /// <summary> /// 回调委托 带参数的 /// </summary> /// <param na ...

  4. 封装、构造方法、private、Static与this关键字、main()_Day07

    1:成员变量和局部变量的区别(理解) (1)定义位置区别:      成员变量:定义在类中,方法外.    局部变量:定义在方法中,或者方法声明上.    (2)初始化值的区别:   成员变量:都有默 ...

  5. (转)python类:magic魔术方法

    原文:https://blog.csdn.net/pipisorry/article/details/50708812 版权声明:本文为博主皮皮http://blog.csdn.net/pipisor ...

  6. Linux后台进程管理以及ctrl+z(挂起)、ctrl+c(中断)、ctrl+\(退出)和ctrl+d(EOF)的区别(转)

    一.后台进程管理命令 fg.bg.jobs.&.ctrl + z.ctrl + c.ctrl + \.ctrl + d1. &加在一个命令的最后,可以把这个命令放到后台执行 ,如fir ...

  7. android的电话监听

    android的电话监听 新建一个项目,结构图如下: PhoneService: package com.demo.tingdianhua; import android.app.Service; i ...

  8. 【JAVA】抽象类,抽象方法

    抽象类不能被实例化,有两个特点: 必须继承才有它的用途: 不能描述对象: 抽象方法: 具体实现由子类决定,最终子类必须实现: 没有方法体: 说明: 抽象类不一定包含抽象方法,抽象方法一定是抽象类.

  9. 18-hadoop-weather案例

    weather案例, 简单分析每年的前三个月的最高温即可, 使用自定义的分组和排序 设计分析 设定多个reduce 每年的数据都很多,如果按照默认情况处理,统计性能是非常慢(因为默认只有一个reduc ...

  10. B 树、B+ 树、B* 树

    B 树.B+ 树.B* 树 作者:July.weedge.Frankie.编程艺术室出品. 说明:本文从B树开始谈起,然后论述B+树.B*树,最后谈到R 树.其中B树.B+树及B*树部分由weedge ...