有一个长为L的狭窄通道,我们假设这个通道在x轴上,其两个出口分别在x=0与x=L处。在这个通道里有N只狼,第i只狼有一个初始位置ai,它想到达位置bi(0<=i<N)。但是这个通道太狭窄了不能允许两只狼相互交换位置他们的位置,因此如果两只狼需要交换它们的位置他们需要同时离开这个通道到x=0或x=L处在那里重新安排进通道的顺序。在x<=0与x>=L处空间足够大可以装下任意数量的狼。那么所有的狼想从ai到bi它们总共最少走多远的距离,输出这个距离。

注意:在x<=0和x>=L的通道外部空间中移动的距离不计算在内;另外,x=0到x=L只能通过通道连通,即通道外面的世界不能从x=0走到x=L处。

解题报告:

用时:2h,2WA

这题一开始想到按照起点排序,然后枚举一个断点,断点左边先全走到0(称之为左集合),右边((称为右集合)先全都走到L,然后问题来了,拍的时候发现有时候到终点的顺序还需要调整,也就是说还有一些狼需要从0走到L,也还有一些要从L走到0,本蒟蒻就不知道怎么处理了.

参考题解:

将左右两边分别都按终点从小到大排序,然后处理终点的矛盾,具体的我不清楚,我就乱写了个\(O(n^2)\)的矛盾处理,在枚举了起点的断点的基础上,我再从右集合中枚举了终点的一个断点,设他的终点为t,把终点小于t的属于左集合的全部都移动到L中,并且把右边集合的中小于t的移动到0,这样矛盾就解决了

然后发现还是不行,发现样例中还有直接从s移动到t的,于是我们选择判掉这一段,显然直接从s到t的必须是连续的一段区间,且左边的那矛盾的一段必须移动到0,右边的矛盾的一段必须移动到L,所以考虑枚举左边一段的终点和右边一段的起点,然后加上中间一段直接移动的即可

复杂度:\(O(n^3)\)

#include <algorithm>
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <cstdio>
#include <cmath>
#define RG register
#define il inline
#define iter iterator
#define Max(a,b) ((a)>(b)?(a):(b))
#define Min(a,b) ((a)<(b)?(a):(b))
using namespace std;
const int N=55,inf=2e8;
int n,L;
struct node{
int s,t;
}a[N];
bool comps(const node &p,const node &q){
return p.s<q.s;
}
bool compt(const node &p,const node &q){
return p.t<q.t;
}
int ans=2e8;
void solve(int x){
int tot=0;
sort(a+1,a+x+1,compt);
sort(a+x+1,a+n+1,compt);
for(int i=1;i<=x;i++)
tot+=a[i].s+a[i].t;
for(int i=x+1;i<=n;i++)
tot+=L-a[i].s+L-a[i].t;
int tmp=0,tl=0;
for(int i=x+1;i<=n;i++){
tmp=0;
for(int j=1;j<=x;j++){
if(a[j].t>=a[i].t)tmp+=L-a[j].t+L-a[j].t;
}
ans=Min(ans,tot+tmp+tl);
tl+=a[i].t+a[i].t;
}
}
bool check(int l,int r,int sl,int sr){
int lm=0,rm=2e8;
for(int i=l;i<=r;i++)lm=Max(lm,a[i].t);
for(int i=sl;i<=sr;i++)rm=Min(rm,a[i].t);
return lm<rm;
}
void work()
{
ans=2e8;
scanf("%d%d",&n,&L);
for(int i=1;i<=n;i++){
scanf("%d%d",&a[i].s,&a[i].t);
}
for(int i=0;i<=n;i++){
sort(a+1,a+n+1,comps);
solve(i);
}
sort(a+1,a+n+1,comps);
int si=0;
for(int i=0;i<=n;i++){
si+=a[i].t+a[i].s;
if(!check(1,i,i+1,n))continue;
int j=i+1,tot=0;
for(;j<=n;j++)
if(!check(i+1,j,j+1,n))break;
for(int k=i+1;k<j;k++)tot+=abs(a[k].t-a[k].s);
for(int k=j;k<=n;k++)tot+=L-a[k].s+L-a[k].t;
ans=Min(ans,si+tot);
}
printf("%d\n",ans);
} int main()
{
int T;cin>>T;
while(T--)work();
return 0;
}

51Nod 1331 狭窄的通道的更多相关文章

  1. 【51nod 1331】狭窄的通道

    Description 有一个长为L的狭窄通道,我们假设这个通道在x轴上,其两个出口分别在x=0与x=L处.在这个通道里有N只狼,第i只狼有一个初始位置ai,它想到达位置bi(0<=i<N ...

  2. 51nod1331 狭窄的通道

    题目传送门 这道题 51nod只Ac了十二个人 没有题解可以研究 所以就自己YY了半天 在这里先感谢一波岚清大爷 orz 然后这道题我分了两种情况 一种是左边的往左跑右边的往右跑 中间有一部分直接走不 ...

  3. 金山中学 rugular SRM 04 ——纪念我的第一次Ak

    虽然只是一场比较简单的比赛 但奈何我也比较弱啊.... T1 一道计算概率的题目 T SRM 04 描述 给个长度为 n 的数列,每次操作能将数列打乱(RandomShuffle),问在期望下需要多少 ...

  4. 游戏AI技术 2

    [Unity3D人工智能编程精粹 2] 1.跟随领队行为. 用靠近(Seek)或追逐(Pursuit)实现跟随领队行为并不好.在Seek中,AI角色会被推向领队,最终与领队占据相同位置.而Pursui ...

  5. 基于SketchUp和Unity3D的虚拟场景漫游和场景互动

    这是上学期的一次课程作业,难度不高但是也一并记录下来,偷懒地拿课程报告改改发上来. 课程要求:使用sketchUp建模,在Unity3D中实现场景漫游和场景互动. 知识点:建模.官方第一人称控制器.网 ...

  6. 默 of 2018:年终总结

    目录 1 概述:在平凡中求变 2 专业分流:一个时代的终点,我的新起点 2.1 我在专业分流前夕的境况 2.2 专业分流情况概述,以及对一篇文章的回顾 2.3 总结与余绪 2.4 附:关于理科与工科的 ...

  7. High-level NavMesh Building Components

    Here we introduce four high level components for the navigation system: //这里我们介绍四个高水平导航系统组件: NavMesh ...

  8. 51Nod 1667 概率好题 - 容斥原理

    题目传送门 无障碍通道 有障碍通道 题目大意 若$L_{i}\leqslant x_{i} \leqslant R_{i}$,求$\sum x_{i} = 0$以及$\sum x_{i} < 0 ...

  9. 用Python的Pandas和Matplotlib绘制股票唐奇安通道,布林带通道和鳄鱼组线

    我最近出了一本书,<基于股票大数据分析的Python入门实战 视频教学版>,京东链接:https://item.jd.com/69241653952.html,在其中给出了MACD,KDJ ...

随机推荐

  1. Python处理图片缩略图

    CPU 密集型任务和 IO 密集型任务分别选择多进程multiprocessing.Pool.map 和多线程库multiprocessing.dummy.Pool.map import os imp ...

  2. 201421123042 《Java程序设计》第5周学习总结

    1. 本周学习总结 1.1 写出你认为本周学习中比较重要的知识点关键词 接口 Comparable Arrays.sort -has a Lambda表达式 1.2尝试使用思维导图将这些关键词组织起来 ...

  3. DML数据操作语言之常用函数

    所谓函数,就是输入某一值,得到相应的输出结果的功能.相当于一个加工厂,给了原料,最终产出成品. 其中原料 就是参数(parameter). 产品 就是返回值. 函数大致可以分为以下五个种类: 算术函数 ...

  4. 09-移动端开发教程-Sass入门

    1. 引言 CSS3之前的CSS都大都是枚举属性样式,而编程语言强大的变量.函数.循环.分支等功能基本都不能在CSS中使用,让CSS的编程黯淡无光,Sass就是一种增强CSS编程的扩展语言(CSS4也 ...

  5. 裸辞两个月,海投一个月,从Android转战Web前端的求职之路

    前言 看到这个标题的童鞋,可能会产生两种想法: 想法一:这篇文章是标题党 想法二:Android开发越来越不景气了吗?前端越来越火了吗? 我一向不喜欢标题党,标题中的内容是我的亲身经历.我是2016年 ...

  6. react-native-image-picker 运用launchCamera直接调取摄像头的缺陷及修复

    在前几天用react-native进行android版本开发当中,用到了"react-native-image-picker"的插件:根据业务的需求:点击按钮-->直接调取摄 ...

  7. testNG常用方法

    1.常用注释: 注解                  描述 @BeforeSuite                       在该套件的所有测试都运行在注释的方法之前,仅运行一次. @After ...

  8. VS2013 工程属性配置

    1. 配置属性设置 设置工程编译输出目录 2. 设置第三方库的头文件的位置 3.设置第三方库(动态库或者静态库链接的搜寻的目录) 4.设置链接的第三方库的名称 注: 第三方库的链接可以通过配置文件来实 ...

  9. hdu1728 逃离迷宫---转弯次数不超过k+BFS

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1728 题目大意: 给你一幅图,给出起点终点和最大转弯次数,判断是否能从起点到终点.'*'表示障碍物. ...

  10. html的基本结构

    html的基本结构 1.<html>内容</html> html文档的文档标记,也称为html开始标记 这对标记分别位于网页的最前端和最后端,表示开始和结束 2.<hea ...