必威体育Betway必威体育官网
当前位置:首页 > IT技术

Rabbit的机器人

时间:2019-10-06 15:43:25来源:IT技术作者:seo实验室小编阅读:54次「手机版」
 

rabbit

在这里插入图片描述

在这里插入图片描述

首先我们明确一点,如果要放障碍物 0 号方格左右最多放一个,因为只要碰到一个就不会继续走过去了,也就是说放置多个障碍物只有最靠近 0 号方格的是有意义的。此外因为要保证最后一次到达没到过的地方,不可能两侧都放,因为这样的话要不就是不满足题意,要不就是其中一个障碍没有意义,所以障碍物的上限是 1 个。然后如果最后一个指令为 L/R,那么障碍物要放一定放在 0 号方格右侧/左侧。且以障碍物放在 0 号方格右侧为例,如果障碍物放在 x 处满足题意的话,放在 x-1 这个位\置也是满足题意的(最后向左能走得更远)。据此我们只要去查找障碍物可以摆放的最右位置,满足单调性质,用二分查就行了

#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<string>
#include<iOStream>
#include<sstream>
#include<set>
#include<map>
#include<queue>
#include<bitset>
#include<vector>
#include<limits.h>
#include<assert.h>
#define SZ(X) ((int)(X).size())
#define ALL(X) (X).begin(), (X).end()
#define REP(I, N) for (int I = 0; I < (N); ++I)
#define REPP(I, A, B) for (int I = (A); I < (B); ++I)
#define FOR(I, A, B) for (int I = (A); I <= (B); ++I)
#define FORS(I, S) for (int I = 0; S[I]; ++I)
#define RS(X) scanf("%s", (X))
#define SORT_unique(c) (sort(c.begin(),c.end()), c.resize(distance(c.begin(),unique(c.begin(),c.end()))))
#define GET_POS(c,x) (lower_bound(c.begin(),c.end(),x)-c.begin())
#define CASET int ___T; scanf("%d", &___T); for(int cs=1;cs<=___T;cs++)
#define MP make_pair
#define PB push_back
#define MS0(X) memset((X), 0, sizeof((X)))
#define MS1(X) memset((X), -1, sizeof((X)))
#define LEN(X) strlen(X)
#define F first
#define S second
using namespace std;
typedef long long LL;
typedef unsigned long long ULL;
typedef long double LD;
typedef pair<int,int> PII;
typedef vector<int> VI;
typedef vector<LL> VL;
typedef vector<PII> VPII;
typedef pair<LL,LL> PLL;
typedef vector<PLL> VPLL;
template<class T> void _R(T &x) { cin >> x; }
void _R(int &x) { scanf("%d", &x); }
void _R(LL &x) { scanf("%lld", &x); }
void _R(double &x) { scanf("%lf", &x); }
void _R(char &x) { scanf(" %c", &x); }
void _R(char *x) { scanf("%s", x); }
void R() {}
template<class T, class... U> void R(T &head, U &... tail) { _R(head); R(tail...); }
template<class T> void _W(const T &x) { cout << x; }
void _W(const int &x) { printf("%d", x); }
void _W(const LL &x) { printf("%lld", x); }
void _W(const double &x) { printf("%.16f", x); }
void _W(const char &x) { putchar(x); }
void _W(const char *x) { printf("%s", x); }
template<class T,class U> void _W(const pair<T,U> &x) {_W(x.F); putchar(' '); _W(x.S);}
template<class T> void _W(const vector<T> &x) { for (auto i = x.begin(); i != x.end(); _W(*i++)) if (i != x.cbegin()) putchar(' '); }
void W() {}
template<class T, class... U> void W(const T &head, const U &... tail) { _W(head); putchar(sizeof...(tail) ? ' ' : '\n'); W(tail...); }
#ifdef HOME
 #define DEBUG(...) {printf("# ");printf(__VA_ARGS__);puts("");}
#else
 #define DEBUG(...)
#endif
int MOD = 1e9+7;
void ADD(LL& x,LL v){x=(x+v)%MOD;if(x<0)x+=MOD;}
/*}}}*/
const int SIZE = 1e6+10;
char s[SIZE];
int N;
bool go(int ban){
    bool update=0;
    int ll=0,rr=0,now=0;
    REP(i,N){
        if(s[i]=='L'){
            now--;
            if(now==ban)now++;
        }
        else{
            now++;
            if(now==ban)now--;
        }
        update=1;
        if(now<ll){
            ll=now;
        }
        else if(now>rr){
            rr=now;
        }
        else update=0;
    }
    return update;
}
int main(){
    R(N);
    RS(s);
    if(go(SIZE)){
        W(0,1);
        return 0;
    }
    int an=0;
    int ll=0,rr=N-1;
    while(ll<rr){
        int mm=(ll+rr+1)/2;
        if(go(mm))ll=mm;
        else rr=mm-1;
    }
    an+=ll;
    ll=0,rr=N-1;
    while(ll<rr){
        int mm=(ll+rr+1)/2;
        if(go(-mm))ll=mm;
        else rr=mm-1;
    }
    an+=ll;
    if(an==0)W(-1);
    else W(1,an);
    return 0;
}

相关阅读

Rabbitmq之相关概念

文章目录RabbitMQ版本RabbitMQ相关概念QueueExchangeExchange常见类型fanoutdirecttopicheadersVirtual hostsdocker安装 RabbitM

RabbitMQ入门到进阶之工作队列Work queues(Round-robi

大纲 此套免费课程视频,本人录播到了腾讯课堂 https://ke.qq.com/course/288116#tuin=5740604a 1.消息中间件概述,使用场景(日志

1、RabbitMQ的简单使用

1、AMQP AMQP,即Advanced Message Queuing Protocol,一个提供统一消息服务的应用层标准高级消息队列协议,是应用层协议的一个开放

rabbitMq集群之镜像模式

RabbitMQ集群的两种模式1)普通模式:默认的集群模式。 2)镜像模式:把需要的队列做成镜像队列。 普通模式:默认的集群模式 RabbitMQ集

分享到:

栏目导航

推荐阅读

热门阅读