이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include<bits/stdc++.h>
using namespace std;
int main()
{
ios_base::sync_with_stdio(NULL);
cin.tie(NULL);
cout.tie(NULL);
long long k,br = 2,y = 1,z;
cin >> k;
while(y*3 <= k) {
y*=6;
br+=2;
}
if(k == 18 || k == 19) {
cout << 4 << " " << 4 << "\n";
cout << "XX";
if(k == 18) {
cout << "dd\n";
}
else {
cout << "Xd\n";
}
cout << "XXXd\n";
cout << "rXXd\n";
cout << "rrr.\n";
return 0;
}
char ans[br][br];
for(long long i = 0; i < br; i++) {
for(long long j = 0; j < br; j++) {
ans[i][j] = '.';
}
}
for(long long i = 1; i < br-1; i+=2) {
ans[i][i] = 'X';
ans[i][i+1] = 'X';
ans[i+1][i] = 'X';
ans[i+1][i+1] = 'X';
ans[i+2][i] = 'r';
ans[i+2][i+1] = 'r';
ans[i][i+2] = 'd';
ans[i+1][i+2] = 'd';
}
for(long long i = 0; i < br-1; i++) {
ans[br-1][i] = 'r';
ans[i][br-1] = 'd';
}
ans[0][0] = 'X';
z = k;
int p = br-2;
while(z > 0) {
if(z%6 >= 3) {
ans[0][p] = 'X';
}
if(z != k) {
if(z%3 > 0) {
ans[0][p+1] = 'X';
if(z%3 > 1) {
ans[p+1][0] = 'X';
}
}
}
p-=2;
z/=6;
}
if(k%3 < 2) {
for(int i = br-2; i >= 0; i--) {
if(ans[i][0] == 'X') {
ans[i][0] = 'r';
break;
}
}
if(k%3 < 1) {
for(int i = br-2; i >= 0; i--) {
if(ans[0][i] == 'X') {
ans[0][i] = 'd';
break;
}
}
}
}
cout << br << " " << br << "\n";
for(long long i = 0; i < br; i++) {
for(long long j = 0; j < br; j++) {
cout << ans[i][j];
}
cout << "\n";
}
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |