QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#364716 | #7943. LIS on Grid | ucup-team004# | WA | 5ms | 3608kb | C++20 | 1.5kb | 2024-03-24 16:13:14 | 2024-03-24 16:13:15 |
Judging History
answer
#include <bits/stdc++.h>
using i64 = long long;
void solve() {
int n, m;
std::cin >> n >> m;
std::vector<int> a(m);
for (int i = 0; i < m; i++) {
std::cin >> a[i];
}
std::vector<std::string> ans;
auto check = [&](int k) {
std::vector<int> f(k);
for (int i = 0; i < k; i++) {
f[i] = n - k + i;
}
ans.assign(n, std::string(m, '.'));
for (int j = 0; j < m; j++) {
int res = a[j];
for (int i = k - 1; i >= 0; i--) {
if (res > 0) {
ans[f[i]][j] = '#';
res--;
}
}
for (int i = k - 1; i >= 0; i--) {
while (res > 0 && f[i] > (i ? f[i - 1] + 1 : 0)) {
res--;
f[i]--;
ans[f[i]][j] = '#';
}
}
if (res > 0) {
return false;
}
}
return true;
};
int lo = 1, hi = n;
while (lo < hi) {
int m = (lo + hi) / 2;
if (check(m)) {
hi = m;
} else {
lo = m + 1;
}
}
std::cout << lo << "\n";
check(lo);
for (int i = 0; i < n; i++) {
std::cout << ans[i] << "\n";
}
}
int main() {
std::ios::sync_with_stdio(false);
std::cin.tie(nullptr);
int t;
std::cin >> t;
while (t--) {
solve();
}
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 0ms
memory: 3608kb
input:
4 2 4 1 1 1 1 3 3 3 3 3 4 4 4 3 2 1 4 5 2 3 4 3 2
output:
1 .... #### 3 ### ### ### 2 ###. #... #### ##.. 2 ..### .#### ####. ###..
result:
ok Correct (4 test cases)
Test #2:
score: -100
Wrong Answer
time: 5ms
memory: 3564kb
input:
5699 5 5 4 5 1 3 5 4 4 3 1 2 4 5 5 2 2 3 3 4 3 4 1 3 2 2 5 5 2 5 3 4 4 4 5 4 1 1 4 1 5 5 3 3 2 5 5 5 5 3 1 3 1 1 5 5 2 4 4 3 2 4 5 2 2 2 2 2 5 5 4 5 3 4 1 5 4 5 4 1 4 5 4 1 1 1 3 4 2 2 4 5 5 2 5 5 2 5 5 5 5 1 2 1 3 5 5 4 4 2 2 3 5 2 5 2 3 5 2 3 3 1 3 5 5 4 2 5 1 1 5 5 4 5 4 1 5 5 4 3 2 5 3 5 5 5 4 1...
output:
3 .#.## ##..# ##.## ##..# ##### 2 ...# #.## #..# #### 2 ....# ....# ..### ##### ####. 2 .### .#.. #### 3 .#### .#... .#.## ##### ##### 2 #..#. #..## #..#. ####. 3 ...## ...## ##.## ##### ##### 1 ..### ..#.. ###.. #.... #.... 2 ...## .###. .#### ###.. ###.. 2 ..... ..... ##### ##### 3 .###. ##... ###...
result:
wrong answer Jury found better answer than participant (test case 21)