Codeforces #617 (Div. 3) C. Yet Another Walking Robot
There is a robot on a coordinate plane. Initially, the robot is located at the point (0,0)(0,0) . Its path is described as a string ss of length nn consisting of characters 'L', 'R', 'U', 'D'.
Each of these characters corresponds to some move:
- 'L' (left): means that the robot moves from the point (x,y)(x,y) to the point (x−1,y)(x−1,y) ;
- 'R' (right): means that the robot moves from the point (x,y)(x,y) to the point (x+1,y)(x+1,y) ;
- 'U' (up): means that the robot moves from the point (x,y)(x,y) to the point (x,y+1)(x,y+1) ;
- 'D' (down): means that the robot moves from the point (x,y)(x,y) to the point (x,y−1)(x,y−1) .
The company that created this robot asked you to optimize the path of the robot somehow. To do this, you can remove any non-empty substring of the path. But this company doesn't want their customers to notice the change in the robot behavior. It means that if before the optimization the robot ended its path at the point (xe,ye)(xe,ye) , then after optimization (i.e. removing some single substring from ss ) the robot also ends its path at the point (xe,ye)(xe,ye) .
This optimization is a low-budget project so you need to remove the shortest possible non-empty substring to optimize the robot's path such that the endpoint of his path doesn't change. It is possible that you can't optimize the path. Also, it is possible that after the optimization the target path is an empty string (i.e. deleted substring is the whole string ss ).
Recall that the substring of ss is such string that can be obtained from ss by removing some amount of characters (possibly, zero) from the prefix and some amount of characters (possibly, zero) from the suffix. For example, the substrings of "LURLLR" are "LU", "LR", "LURLLR", "URL", but not "RR" and "UL".
You have to answer tt independent test cases.
The first line of the input contains one integer tt (1≤t≤10001≤t≤1000 ) — the number of test cases.
The next 2t2t lines describe test cases. Each test case is given on two lines. The first line of the test case contains one integer nn (1≤n≤2⋅1051≤n≤2⋅105 ) — the length of the robot's path. The second line of the test case contains one string ss consisting of nn characters 'L', 'R', 'U', 'D' — the robot's path.
It is guaranteed that the sum of nn over all test cases does not exceed 2⋅1052⋅105 (∑n≤2⋅105∑n≤2⋅105 ).
For each test case, print the answer on it. If you cannot remove such non-empty substring that the endpoint of the robot's path doesn't change, print -1. Otherwise, print two integers ll and rr such that 1≤l≤r≤n1≤l≤r≤n — endpoints of the substring you remove. The value r−l+1r−l+1 should be minimum possible. If there are several answers, print any of them.
4
4
LRUD
4
LURD
5
RRUDU
5
LLDDR
1 2
1 4
3 4
-1
数据结构题,考stl的map怎么用。用map<pair<int,int>,int>存储走过的地方,是坐标点到字符串下标的映射。只要发现下一个走到的点已经出现在字典里了,说明这一段走的路就是在兜圈子,可以直接删掉,这时候更新答案的值同时把这个点的坐标对应的值更新成最新的(因为以后要是再一次经过的话到当前位置的字符串长度肯定小于到更新前位置的字符串的长度)。最后输出答案即可。
#include <bits/stdc++.h>
using namespace std;
int main()
{
int t;
cin>>t;
map<pair<int,int>,int>m;
while(t--)
{
int n;
scanf("%d",&n);
int i;
m.clear();//不要忘记清空
m[{,}]=;
int x=,y=;
int ans=;
int beg=-,end=-;
char s[];
scanf("%s",s);
for(i=;i<=n;i++)
{
char c=s[i-];
if(c=='L')
{
x-=;
}
else if(c=='R')
{
x+=;
}
else if(c=='U')
{
y+=;
}
else if(c=='D')
{
y-=;
}
if(m.find({x,y})!=m.end())
{
if(ans>i-m[{x,y}]+)
{
ans=i-m[{x,y}]+;//更新答案
beg=m[{x,y}]+;
end=i;
m[{x,y}]=i;
}
else
{
m[{x,y}]=i;//ans不必更新的话只更新这个点对应的值即可
}
}
else
{
m[{x,y}]=i;//之前没发现的话直接添加进字典 ,经过第i次操作到达(x,y)
}
}
if(ans!=&&beg!=-)cout<<beg<<' '<<end<<endl;
else cout<<-<<endl;
}
return ;
}
Codeforces #617 (Div. 3) C. Yet Another Walking Robot的更多相关文章
- Codeforces #617 (Div. 3) D. Fight with Monsters(贪心,排序)
There are nn monsters standing in a row numbered from 11 to nn . The ii -th monster has hihi health ...
- Codeforces #617 (Div. 3)B. Food Buying
Mishka wants to buy some food in the nearby shop. Initially, he has ss burles on his card. Mishka ca ...
- Codeforces Round #605 (Div. 3) B. Snow Walking Robot(构造)
链接: https://codeforces.com/contest/1272/problem/B 题意: Recently you have bought a snow walking robot ...
- Codeforces Round #617 (Div. 3) 补题记录
1296A - Array with Odd Sum 题意:可以改变数组中的一个数的值成另外一个数组中的数,问能不能使数组的和是个奇数 思路:签到,如果本来数组的和就是个奇数,那就OK 如果不是,就需 ...
- Codeforces Round #617 (Div. 3) 题解
又是隔了一年才来补题的我 A.B水题就不用说了 C - Yet Another Walking Robot C题我居然卡了一会,最后决定用map水,结果出来看了看题解,居然真的是map...没想到会出 ...
- [CF百场计划]Codeforces Round #617 (Div. 3)
A. Array with Odd Sum Description You are given an array \(a\) consisting of \(n\) integers. In one ...
- C. Yet Another Walking Robot Round #617 (Div. 3)()(map + 前后相同状态的存储)
C. Yet Another Walking Robot time limit per test 1 second memory limit per test 256 megabytes input ...
- Codeforces #344 Div.2
Codeforces #344 Div.2 Interview 题目描述:求两个序列的子序列或操作的和的最大值 solution 签到题 时间复杂度:\(O(n^2)\) Print Check 题目 ...
- Codeforces #345 Div.1
Codeforces #345 Div.1 打CF有助于提高做题的正确率. Watchmen 题目描述:求欧拉距离等于曼哈顿距离的点对个数. solution 签到题,其实就是求有多少对点在同一行或同 ...
随机推荐
- C#系统库的源代码
.NET Core:https://github.com/dotnet/corefx .NET Framework:https://referencesource.microsoft.com
- php-cp(php连接池)扩展的安装
今天看到php有连接池的扩展,不管效果怎么样,都值得一试,这样才会有突破. 先从guthub上搜索源码:[ https://github.com/swoole/php-cp ] 通过命令clone到自 ...
- javaweb项目运转流程
做web项目,不仅要会做,还需要了解其工作流程,为什么这么做!这些知道了.其他的都是渣渣.上图!对于web 项目了解他的运行流程之后,基本其他的都不是问题.web项目还是很简单的 这是简化的开发时常用 ...
- StatelessWidget 无状态组件 StatefulWidget 有状态组件 页面上绑定数据、改变页面数据
一.Flutter 中自定义有状态组件 在 Flutter 中自定义组件其实就是一个类,这个类需要继承 StatelessWidget/StatefulWidget. StatelessWidget ...
- Java面向对象编程 -5.2
静态代码块 静态代码块主要指的是使用static关键字定义的代码块 静态块的定义需要考虑到两种情况: 主类中定义静态块 非主类中定义静态块 静态块执行主要是给static属性进行初始化的 此时可以发现 ...
- 消息队列(五)--- RocketMQ-消息存储2
概述 RocketMQ存储中主要用到以下知识点: mmap 文件映射 内存池 异步刷盘 consumeQueue 同时本节将介绍各个重要的类,本篇文章将介绍 mmap 文件映射的相关方法和内存池相关知 ...
- java 编译java文件 以及生成可执行jar
1.新建java project: 2.src下新建包以及class文件: 3.打包: 5.选取目标mainclass 很关键决定jar是否可执行: 7.build jar : 8:artifact ...
- werkeug的WSGI服务器解析
werkeug的WSGI服务器解析 1. WSGI 1.1. wsgi与flask flask默认的wsgi引用自wekurg 声明app:FLASK对象 app.run() run_ ...
- vscode vue js 开发插件配置
安装 vetur { // 自动补全触发范围---双引号内的字符串也可以触发补全 "editor.quickSuggestions": { "other": t ...
- 杭电2033 人见人爱A+B
人见人爱A+B Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Sub ...