shortcut(NOIP模拟赛)(裸的排序)
原题:
Description
Mirek有一条每天从他家去大学工作的最喜欢的路。这个路径由若干个部分组成,且每个部分是10米长的直线。每一个部分是直线连接(没有拐弯)上一个部分或垂直连接上一个部分。在走过每一个部分后,Mirek会休息下欣赏美丽的自然景色。在他走路的过程之中,他不会重复访问一个地点
昨天,Mirek在party中熬夜到很迟,并且今天他迟起床了。他意识到他会错过第一堂课除非他改变他平时走的路径。他计划找一条捷径(shortcut)但他希望捷径尽量的短。捷径必须是水平的或者是垂直的并且连接两个Mirek原先路径的休息的地点。
请帮助Mirek找到最短的捷径。
Task
写一个程序:
读入Mirek的路径,计算路径上面最短的捷径,输出结果。
Input
第一行包含一个整数n(3<=n<=250000)作为路径的部分的个数。第二行包含一组长度为n的序列,每个字母为N,E,S或W,
之间没有空格。每一个字母描述路径的一个部分。字母N,E,S或W表示Mirek向这些方向走了10米。你可以假设至少存在一个捷径。
Output
第一行也就是唯一的一行包括 l,b,e 3个整数和一个字母d,用空格隔开。整型变量l是最短的捷径(以长度10为单位)。整数b和e是休息点的编号,也就是捷径的起点和终点(Mirek的home的编号为0,大学的编号为n)。字母d是捷径的方向。如果有超过1条最短的捷径存在,你应该输出起点最小的,如果有多个捷径最短,起点相同的捷径,你应该输出终点编号最大的。
Sample Input(shortcut.in)
12
NNNENNWWWSSW
Sample Output(shortcut.out)
2 3 11 W
题目满足:
45%的数据n<=1000
100%的数据n<=250000
时限 2s
首先我们要理解shortcut的含义,他是一条在网格上的线段,且不与路径重合
然后我们想到了一个性质,即判断2点之间有无路径及判断点的指针与另一点的指针的差是否为1,若为1则为路径
然后就可以扫描线扫描点+统计答案。做2次即可
下面贴代码
#include<iostream>
#include<cstdio>
#include<algorithm>
#define inf 0x3f3f3f3f
using namespace std;
int point[][];
int sorted[];
int n,bestlen,bestbeg,bestend;
bool cmp(int a,int b){return (point[a][]<point[b][])||((point[a][]==point[b][])&&(point[a][]<point[b][]));}
bool cmp2(int a,int b){return (point[a][]<point[b][])||((point[a][]==point[b][])&&(point[a][]<point[b][]));}
void sort1(int step)
{
for(int i=;i<=n;i++)
sorted[i]=i;
sort(sorted,sorted+n+,step==?cmp:cmp2);
}
void solve(int step){
sort1(step);
for(int i=;i<=n;i++)
{
if(point[sorted[i-]][step]==point[sorted[i]][step])
{
int len=abs(point[sorted[i-]][-step]-point[sorted[i]][-step]);
int b=sorted[i-]<sorted[i]?sorted[i-]:sorted[i];
int e=b==sorted[i-]?sorted[i]:sorted[i-];
if(e-b!=)
if((len<bestlen)||(len==bestlen&&b<bestbeg)||((len==bestlen)&&(b==bestbeg)&&(e>bestend)))
bestlen=len,bestbeg=b,bestend=e;
}
}
}
int main(){
freopen("shortcut.in","r",stdin);
freopen("shortcut.out","w",stdout);
bestbeg=n+;bestend=-;bestlen=inf;
scanf("%d",&n);
int x=,y=;
char ch[];
scanf("%s",ch);
point[][]=;point[][]=;
for(int i=;i<n;i++)
{
if(ch[i]=='N')++y;
else if(ch[i]=='S')--y;
else if(ch[i]=='W')--x;
else ++x;
point[i+][]=x;point[i+][]=y;
}
solve();
solve();
char ans;
if(point[bestbeg][]==point[bestend][])ans=point[bestbeg][]<point[bestend][]?'N':'S';
else ans=point[bestbeg][]<point[bestend][]?'E':'W';
printf("%d %d %d %c\n",bestlen,bestbeg,bestend,ans);
return ;
fclose(stdin);
fclose(stdout);
}
shortcut(NOIP模拟赛)(裸的排序)的更多相关文章
- 【BZOJ 2957】楼房重建&&Codechef COT5 Count on a Treap&&【NOIP模拟赛】Weed 线段树的分治维护
线段树是一种作用于静态区间上的数据结构,可以高效查询连续区间和单点,类似于一种静态的分治.他最迷人的地方在于“lazy标记”,对于lazy标记一般随我们从父区间进入子区间而下传,最终给到叶子节点,但还 ...
- NOIP模拟赛 by hzwer
2015年10月04日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...
- 队爷的讲学计划 CH Round #59 - OrzCC杯NOIP模拟赛day1
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的讲学计划 题解:刚开始理解题意理解了好半天,然后发 ...
- 队爷的新书 CH Round #59 - OrzCC杯NOIP模拟赛day1
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的新书 题解:看到这题就想到了 poetize 的封 ...
- CH Round #52 - Thinking Bear #1 (NOIP模拟赛)
A.拆地毯 题目:http://www.contesthunter.org/contest/CH%20Round%20%2352%20-%20Thinking%20Bear%20%231%20(NOI ...
- NOIP模拟赛-2018.11.6
NOIP模拟赛 今天想着反正高一高二都要考试,那么干脆跟着高二考吧,因为高二的比赛更有技术含量(我自己带的键盘放在这里). 今天考了一套英文题?发现阅读理解还是有一些困难的. T1:有$n$个点,$m ...
- NOI.AC NOIP模拟赛 第五场 游记
NOI.AC NOIP模拟赛 第五场 游记 count 题目大意: 长度为\(n+1(n\le10^5)\)的序列\(A\),其中的每个数都是不大于\(n\)的正整数,且\(n\)以内每个正整数至少出 ...
- NOI.AC NOIP模拟赛 第一场 补记
NOI.AC NOIP模拟赛 第一场 补记 candy 题目大意: 有两个超市,每个超市有\(n(n\le10^5)\)个糖,每个糖\(W\)元.每颗糖有一个愉悦度,其中,第一家商店中的第\(i\)颗 ...
- NOI.AC NOIP模拟赛 第四场 补记
NOI.AC NOIP模拟赛 第四场 补记 子图 题目大意: 一张\(n(n\le5\times10^5)\)个点,\(m(m\le5\times10^5)\)条边的无向图.删去第\(i\)条边需要\ ...
- NOI.AC NOIP模拟赛 第三场 补记
NOI.AC NOIP模拟赛 第三场 补记 列队 题目大意: 给定一个\(n\times m(n,m\le1000)\)的矩阵,每个格子上有一个数\(w_{i,j}\).保证\(w_{i,j}\)互不 ...
随机推荐
- lambda & 三元运算
lambda & 三元运算 lambda: 1 >>> def add(x,y): #定义一个加法函数 2 return x+y ...
- 笔记-python-lib-requests常用类/方法/属性
笔记-python-lib-requests常用类/方法/属性 1. requests模块常用类/方法/属性 在使用中发现对requests模块不够熟悉,写了几个案例后重新整理了一下文档,罗 ...
- Java虚拟机之搜索class文件
Java命令 Java虚拟机的工作是运行Java应用程序.和其他类型的应用程序一样,Java应用程序也需要一个入口点,这个入口点就是我们熟知的main()方法.如果一个类包含main()方法,这个类就 ...
- loj2472 「九省联考 2018」IIIDX
ref #include <algorithm> #include <iostream> #include <cstdio> using namespace std ...
- erlang连接mysql [转]
转自: http://blog.csdn.net/flyinmind/article/details/7740540 项目中用到erlang,同时也用到mysql.惯例,google. 但是,按照网上 ...
- Start with PJSIP on windows
To overcome the project of HD video conferencing systerm,I should learn to use the PJSIP. I should m ...
- CocosCreator设置启动场景
刚开始接触CocosCreator,在调试时,如果有多个场景,不知道如何设置将某个指定的场景设置为启动场景,折腾了一圈,找到了设置的地方, 记录一下. 点击项目->项目设置 在预览运 ...
- GTID环境中手动修复主从故障一例(Error 1146)
Preface In my last test of pt-heartbeat,both of master and slave were out of disk.And the my ...
- ASP.NET Core API ---状态码
摘录自:https://www.cnblogs.com/cgzl/p/9047626.html 状态码是非常重要的,因为只有状态码会告诉API的消费者: 请求是否如预期的成功,或者失败 如果出现了错误 ...
- 孤荷凌寒自学python第五天初识python的列表
孤荷凌寒自学python第五天 列表 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) 粗俗地区分列表,可以这样理解,定义或print列表后显示时,列表中的各元素都是用一个方括号[]括起来的. ...