QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#710967 | #8981. Kangaroo Puzzle | xhytom | RE | 1ms | 3928kb | C++23 | 3.4kb | 2024-11-04 23:29:59 | 2024-11-04 23:30:01 |
Judging History
answer
/*
_/ _/ _/ _/ _/ _/ _/_/_/_/_/ _/_/ _/ _/
_/ _/ _/ _/ _/ _/ _/ _/ _/ _/ _/
_/ _/ _/ _/ _/ _/ _/ _/ _/ _/_/ _/_/
_/_/ _/_/_/_/_/ _/ _/ _/ _/ _/ _/ _/
_/ _/ _/ _/ _/ _/ _/ _/ _/ _/
_/ _/ _/ _/ _/ _/ _/ _/ _/ _/
_/ _/ _/ _/ _/ _/ _/_/ _/ _/
*/
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
using i64 = long long;
#define rep(i,a,n) for(int i=a;i<n;i++)
#define per(i,a,n) for(int i=n-1;i>=a;i--)
#define fastio ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
#define multi int _;cin>>_;while(_--)
#define int long long
#define pb push_back
#define eb emplace_back
ll gcd(ll a,ll b){ return b?gcd(b,a%b):a;}
mt19937_64 mrand(chrono::steady_clock().now().time_since_epoch().count());
int rnd(int l,int r){ return mrand() % (r - l + 1) + l;}
#ifdef localfreopen
#define debug(x) cerr << #x << " = " << (x) << endl;
void test() {cerr << "\n";}
template<typename T, typename... Args>
void test(T x, Args... args) {cerr << x << " ";test(args...);}
#else
#define debug //
#define test //
#endif
const ll MOD = 998244353;
// const ll MOD = 1e9+7;
ll ksm(ll x,ll y){ll ans=1;x%=MOD;while(y){if(y&1)ans=ans*x%MOD;x=x*x%MOD,y/=2;}return ans;}
const int P1 = 972152273, base1 = 809;
const int P2 = 905563261, base2 = 919;
const ll N = 200005;
//head
signed main()
{
#ifdef localfreopen
// freopen("1.in","r",stdin);
#endif
fastio
std::cout << std::fixed << std::setprecision(10);
int n, m;
std::cin >> n >> m;
std::vector is(n + 1, std::vector<int> (m + 2));
for (int i = 1; i <= n; i++) {
std::string s;
std::cin >> s;
for (int j = 0; j < m; j++) {
is[i][j + 1] = s[j] - '0';
}
}
std::string ans;
std::vector<std::pair<int, int>> D = {{0, 1}, {0, -1}, {1, 0}, {-1, 0}};
std::vector<char> target = {'R', 'L', 'D', 'U'};
auto dfs = [&](auto self, int x, int y, int fx, int fy, int rx, int ry, std::string s)->void{
int cnt = 0;
for (int k = 0; k < 4; k++) {
auto [dx, dy] = D[k];
int nx = x + dx, ny = y + dy;
if (nx < 1 || nx > n || ny < 1 || ny > m || is[nx][ny] == 0 || (nx == fx && ny == fy)) continue;
cnt++;
self(self, nx, ny, x, y, rx, ry, s + target[k]);
}
if (cnt == 0) {
ans += s;
}
};
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= m; j++) {
if (is[i][j] == 1) {
int cnt = 0;
for (auto [dx, dy] : D) {
int nx = i + dx, ny = j + dy;
if (nx >= 1 && nx <= n && ny >= 1 && ny <= m && is[nx][ny] == 1) {
cnt++;
}
}
if (cnt == 1) {
dfs(dfs, i, j, 0, 0, i, j, "");
}
}
}
}
while (ans.size() < 50000) ans += "LRDU"[rnd(0, 3)];
assert(ans.size() <= 50000);
std::cout << ans << "\n";
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 1ms
memory: 3928kb
input:
4 4 1111 1001 1001 1110
output:
UULLLDDDRRLLUUURRRDDDDURULUDRRDRDDLDURURUDRRDLULULRULUDDULDLLRDRDUDUDURDURRUDUURDUUURULUDDRUDURRRDULDDRLLULUDRRRDUDLULLUDUUUDRDDDRRDDUULURDRDULLRDDDRDLULDDRRRDUULLLULDDLDULUDRDRLLLRDURDUULDLRLRRLURDLRRLDULRDRLLDLLDURDUDDURDDRULUULDLULDLUDLURRRRLLRLLDLUDDLRLRURLRRDULUDDRULDLRRDDDLRUDRDDRRDRLLLDDULDUD...
result:
ok AC
Test #2:
score: 0
Accepted
time: 0ms
memory: 3728kb
input:
2 15 111111111111111 101010101010101
output:
URRRRRRRRRRRRRRDURRRRRRRRRRRRDURRRRRRRRRRDURRRRRRRRDURRRRRRDURRRRDURRDURRRRRRRRRRRRDURRRRRRRRRRDURRRRRRRRDURRRRRRDURRRRDURRDULLDURRRRRRRRRRDURRRRRRRRDURRRRRRDURRRRDURRDULLLLDULLDURRRRRRRRDURRRRRRDURRRRDURRDULLLLLLDULLLLDULLDURRRRRRDURRRRDURRDULLLLLLLLDULLLLLLDULLLLDULLDURRRRDURRDULLLLLLLLLLDULLLLLLL...
result:
ok AC
Test #3:
score: 0
Accepted
time: 1ms
memory: 3804kb
input:
1 2 11
output:
RLDLRLRRUUUUDDUULURLDDLDURRDDRUUDDURRDURLRDURRDRLUURDDDULDLRULLLRUUURDULDUURLUULLLURLRLUDDDLRRRRRLRDLLDLLRDURDLLLLUURLUDRDDRURURRLRDRLURUUDLLRDDRLURLURDRRRUDUULDDRLURLLURRDLULRRURUULLRRURDDLDLDLDRULUDRRUULRUURDDUDLLDDRURLLRDLULDLRLRDLURURDRUUURRDLLLLDUULLUURRRDUDURRLUDLDURUUUUUUDRLLURUDLRRUULULRRRLD...
result:
ok AC
Test #4:
score: 0
Accepted
time: 1ms
memory: 3736kb
input:
2 1 0 1
output:
RRRURDRLRURUUDLLRLLRLDULLRLRRRRRUDLLUUULDLLDUULULRDULDURDDLLDRULDDDLDDLRUULDUDDDDUUUDUURLDRRLULUULLDULUULUUDDRRURDDDUUDUULDLURURDUURRUDDRULUDDDDUDDURLLLLDURRRLUURUUDDUULLRLRUDLRDRLLUUDLDLUURURDULLULULRUUDUDLLLLDLURDDUURLRLLLDDLUDLLULLDLDUDURRUUUULRLLDULDUDLDDUDLDDUDUDUDDULUDLLURDURLUULLRDLUDURLRURDD...
result:
ok AC
Test #5:
score: 0
Accepted
time: 1ms
memory: 3700kb
input:
20 20 00000000000000000000 00000000000000000000 00000000000000000000 00000000000000010000 00000000000000010100 00000000000000111110 11001100000001101001 01110100111001000111 10011111101111001101 11110100110101001001 01000000001101011101 00000000000011010000 01000000000110010000 11100000001010110000 ...
output:
DDRRRDDRRUDDRDDDLDLDDLLLULLDLLLLLDLLLUDDLDLDDLLLULLDLLLLLDLLDDDLDLDDLLLULLDLLLLLULLULDDLDLDDLLLULLDLLLDDDLDLDDLLLULLDLLLUULDDLDLDDLLLULLDDRDDLDLDDLLDDLDDLDLDDDDDLDLDDLDLDDDDDLDDDRDDLDLDDDDDLDDDDLLDLLLDDLDLDDDDDLDDDDLLDLLUDDLDLDDDDDLDDDDLLDLDDDRRDDLDLDDDDDLDDDDLLDLDDDLLLULLULULULLDDDRRDDLDLDDDDDLDDDD...
result:
ok AC
Test #6:
score: -100
Runtime Error
input:
20 20 10101010000000111100 11111110000000100111 00101000000000000101 11101100000000001011 01000101100000001101 01001110111010111011 00111011001011101010 00101001111001001111 11001011000111011010 01010110000000110100 11110010000101011100 10011111101101110011 10101000100111000110 11100111111100111011 ...