P7683
Mars_Dingdang · · 题解
洛谷上这道题的第一篇题解。上海加油。
题目大意
Aladdin 已经厌倦了宫殿里的生活。他有一份稳定的工作,他的妻子 Jasmine 和孩子们都在路上,生活变得单调。在这一切的驱使下,他决定在安顿下来之前再进行一次冒险。他决定找到 Golden Pear,这是一件极为珍贵的传奇文物,至今无人能找到。
Aladdin 正在寻找的沙漠可以被看作是一个
Aladdin 星期一在沙漠的左上角
- 如果当前的网格里有一个醒着的巫师,那么 Aladdin 会根据巫师说的话向左或向右转
90 度。 - 如果向前走会把 Aladdin 带出沙漠,他会转过
180 度。 - Aladdin 向前移动了一格,这将花费他一天的时间。
对于每个巫师,我们都知道他的位置和一周中每一天的活动计划。每个巫师的日程表是一个由七个字母(仅包含 L、R 或 S)组成的字符串,每个字符告诉我们巫师在一周中的某一天(从星期一开始)做什么。字母 L 表示 Aladdin 将在这一天被告知向左转,R 表示 Aladdin 将在这一天被告知向右转,而 S 表示巫师那天正在睡觉。
一个古老的预言说,在改变
大体思路
按照题意,定义一个状态为
记
由于距离目标
具体实现时,还需要在永久循环的开头判断 L,R 以及边界的转向,并调整
完整代码
#include <bits/stdc++.h>
using namespace std;
#define rep(ii,aa,bb) for(re int ii = aa; ii <= bb; ii++)
#define Rep(ii,aa,bb) for(re int ii = aa; ii >= bb; ii--)
typedef long long ll;
typedef unsigned long long ull;
typedef double db;
typedef pair<int, int> PII;
const int maxn = 205;
namespace IO_ReadWrite {
#define re register
#define gg (p1 == p2 && (p2 = (p1 = _buf) + fread(_buf, 1, 1<<21, stdin), p1 == p2) ? EOF :*p1++)
char _buf[1<<21], *p1 = _buf, *p2 = _buf;
template <typename T>
inline void read(T &x){
x = 0; re T f=1; re char c = gg;
while(c > 57 || c < 48){if(c == '-') f = -1;c = gg;}
while(c >= 48 &&c <= 57){x = (x<<1) + (x<<3) + (c^48);c = gg;}
x *= f;return;
}
inline void ReadChar(char &c){
c = gg;
while(!isalpha(c)) c = gg;
}
template <typename T>
inline void write(T x){
if(x < 0) putchar('-'), x = -x;
if(x > 9) write(x/10);
putchar('0' + x % 10);
}
template <typename T>
inline void writeln(T x){write(x); putchar('\n');}
}
using namespace IO_ReadWrite;
int dx[4] = {0, 1, 0, -1},
dy[4] = {1, 0, -1, 0};//right, down, left, up
int N, M, K, turns[maxn][maxn][4][8];
char mp[maxn][maxn][8];
ll date[maxn][maxn][4][8];
int main () {
scanf("%d%d%d", &N, &K, &M);
rep(i, 1, M) {
int x, y;
scanf("%d%d", &x, &y);
scanf("%s", mp[x][y]);
}
ll ans = 0;
int x = 1, y = 1, dir = 0, day = 0, k = 0;
while(1) {
if(mp[x][y][day] == 'L') dir = (dir + 3) % 4, k ++;
if(mp[x][y][day] == 'R') dir = (dir + 1) % 4, k ++;
int nx = x + dx[dir], ny = y + dy[dir];
if(nx < 1 || nx > N || ny < 1 || ny > N) dir = (dir + 2) % 4, k ++;
if(date[x][y][dir][day]) {
int newK = k - turns[x][y][dir][day];
int left = K - k;
ans += (left / newK) * (ans - date[x][y][dir][day]);
k += (left / newK) * newK;
}
date[x][y][dir][day] = ans;
turns[x][y][dir][day] = k;
if(k >= K) break;
x = x + dx[dir], y = y + dy[dir];
ans ++;
if(++day >= 7) day = 0;
}
writeln(ans);
return 0;
}