QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#854014 | #9926. Flipping Paths | ucup-team3691# | TL | 1ms | 3624kb | C++20 | 4.5kb | 2025-01-11 20:58:32 | 2025-01-11 20:58:37 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
using namespace chrono;
using ll = long long;
using ull = unsigned long long;
string to_string(const string &s) {
return '"' + s + '"';
}
string to_string(bool b) {
return b ? "true" : "false";
}
template <typename A, typename B>
string to_string(const pair<A, B> &p) {
return "(" + to_string(p.first) + ", " + to_string(p.second) + ")";
}
template <typename T>
string to_string(const T &v) {
string s = "{";
bool first = true;
for (const auto &it : v) {
if (!first)
s += ", ";
else
first = false;
s += to_string(it);
}
return s += "}";
}
void debug_out() {
cerr << endl;
}
template <typename T, typename... Args>
void debug_out(const T &first, const Args&... rest) {
cerr << to_string(first) << " ";
debug_out(rest...);
}
#define debug(...) cerr << "[" << #__VA_ARGS__ << "]:", debug_out(__VA_ARGS__)
mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());
auto startTime = high_resolution_clock::now();
int get_time() {
auto stopTime = chrono::high_resolution_clock::now();
auto duration = duration_cast<milliseconds>(stopTime - startTime);
return duration.count(); // in ms
}
int n, m;
bool solve(vector<vector<int>> v) {
if (v[1][1] != v[n][m]) {
return 0;
}
auto v2 = v;
for (int i = 1; i <= n; ++i) {
for (int j = 1; j <= m; ++j) {
v2[i][j] = 0;
}
}
auto v4 = v2;
if (v[1][1] == 1) {
v2[1][1] = 1;
}
for (int d = 1; d <= n + m - 1; ++d) {
for (int i = 1; i <= n; ++i) {
int j = d - i + 1;
if (j < 1 || j > m) {
continue;
}
if (v[i][j] % 2 != v2[i][j] % 2) {
return 0;
}
if (v[i][j] > 400) {
assert(1 == 0);
return 0;
}
if (j + 1 <= m) {
if (i + 1 <= n) {
if (v[i][j + 1] % 2 != v2[i][j + 1] % 2) {
if (v2[i][j] == 0) {
v2[i][j] += 2; // 2 * n * m -> (n + m)
v4[i][j] += 2;
}
int m = v2[i][j];
if (m % 2 == 0) {
--m;
}
v2[i][j + 1] += m;
v2[i + 1][j] += v2[i][j] - m;
} else {
int m = v2[i][j];
if (m % 2 == 1)
--m;
v2[i][j + 1] += m;
v2[i + 1][j] += v2[i][j] - m;
}
} else {
v2[i][j + 1] += v2[i][j];
}
} else if (i + 1 <= n) {
v2[i + 1][j] += v2[i][j];
}
}
}
for (int d = n + m - 1; d >= 1; --d) {
for (int i = 1; i <= n; ++i) {
int j = d - i + 1;
if (j < 1 || j > m) {
continue;
}
if (i + 1 <= n) {
if (v4[i + 1][j] > 0) {
v2[i][j] += v4[i + 1][j];
v4[i][j] += v4[i + 1][j];
v4[i + 1][j] = 0;
}
}
if (j + 1 <= m) {
if (v4[i][j + 1] > 0) {
v2[i][j] += v4[i][j + 1];
v4[i][j] += v4[i][j + 1];
v4[i][j + 1] = 0;
}
}
}
}
cout << "YES\n";
cout << v2[n][m] << "\n";
//assert(v2[n][m] <= (n + m));
auto v3 = v;
while (v2[n][m] > 0) {
int i = 1, j = 1;
string s;
while (i < n || j < m) {
--v2[i][j];
v[i][j] ^= 1;
if (j + 1 <= m && v2[i][j + 1] > 0) {
s.push_back('R');
++j;
} else if (i + 1 <= n && v2[i + 1][j] > 0) {
s.push_back('D');
++i;
} else {
assert(1 == 0);
}
}
--v2[i][i];
v[i][j] ^= 1;
cout << s << "\n";
}
for (int i = 1; i <= n; ++i) {
for (int j = 1; j <= m; ++j) {
if (v[i][j] == 1) {
while (1);
}
//assert(v[i][j] == 0);
}
}
return 1;
}
void solve() {
cin >> n >> m;
//n = 4;
//m = 4;
vector<vector<int>> v(n + 1, vector<int>(m + 1));
for (int i = 1; i <= n; ++i) {
string s;
cin >> s;
for (int j = 1; j <= m; ++j) {
v[i][j] = (s[j - 1] == 'W') ? 0 : 1;
//v[i][j] = rng() % 2;
}
}
bool ok = solve(v);
if (ok) {
return;
}
for (int i = 1; i <= n; ++i) {
for (int j = 1; j <= m; ++j) {
v[i][j] ^= 1;
}
}
ok = solve(v);
if (!ok) {
cout << "NO\n";
}
}
int main() {
cin.tie(NULL);
ios_base::sync_with_stdio(false);
int t = 1;
cin >> t;
while (t--)
solve();
return 0;
}
詳細信息
Test #1:
score: 100
Accepted
time: 1ms
memory: 3624kb
input:
4 3 3 WBB BWB BBW 1 5 WWWWW 2 2 BB BB 4 1 W B B W
output:
YES 2 RRDD DDRR YES 0 YES 0 NO
result:
ok ok (4 test cases)
Test #2:
score: -100
Time Limit Exceeded
input:
323 1 2 BB 1 2 BW 1 2 WB 1 2 WW 2 1 B B 2 1 B W 2 1 W B 2 1 W W 1 3 BBB 1 3 BBW 1 3 BWB 1 3 BWW 1 3 WBB 1 3 WBW 1 3 WWB 1 3 WWW 2 2 BB BB 2 2 BB BW 2 2 BB WB 2 2 BB WW 2 2 BW BB 2 2 BW BW 2 2 BW WB 2 2 BW WW 2 2 WB BB 2 2 WB BW 2 2 WB WB 2 2 WB WW 2 2 WW BB 2 2 WW BW 2 2 WW WB 2 2 WW WW 3 1 B B B 3 ...
output:
YES 1 R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R R ...