QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#412835 | #6743. water235 | Guren_ | WA | 0ms | 3576kb | C++20 | 7.9kb | 2024-05-16 20:11:53 | 2024-05-16 20:11:53 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
int main()
{
int n,m;
cin >> n >> m;
if(m==1)
{
cout << n / 2 + 1 << endl;
for (int i = 1; i <= n-1;i++)
{
if(i%2==1)
cout << "1" << endl;
else
{
cout << "0" << endl;
}
}
cout << 1 << endl;
}
else
{
if(n%2==1)
{
if(m==2)
{
cout << m + (n - 1) / 2 << endl;
cout<<1<<" "<<1<<endl;
int flag = 1;
for (int i = 2; i <= n; i++)
{
if (i % 2 == 1)
{
if (flag == 1)
{
for (int j = 1; j <= m; j++)
{
if (j % 2 == 1)
{
cout << "1 ";
}
else
{
cout << "0 ";
}
}
cout << endl;
}
if (flag == 0)
{
for (int j = 1; j <= m; j++)
{
if (j % 2 == 0)
{
cout << "1 ";
}
else
{
cout << "0 ";
}
}
cout << endl;
}
if (flag == 1)
flag = 0;
else
flag = 1;
}
else
{
for (int j = 1; j <= m; j++)
{
cout << "0 ";
}
cout << endl;
}
}
}
else
{
// cout<<n/3
long long ans = 0;
int flag1 = 0;
for (int i = 1; i <= n; i += 2)
{
if (m % 2 == 1)
{
if (i % 2 == 1 && flag1 == 0)
{
ans += m / 2 + 1;
}
else if (i % 2 == 1 && flag1 == 1)
{
ans += m / 2;
}
if (flag1 == 0)
flag1 = 1;
else
flag1 = 0;
}
else
{
if (i % 2 == 1 && flag1 == 0)
{
ans += m / 2;
}
else if (i % 2 == 1 && flag1 == 1)
{
ans += m / 2;
}
if (flag1 == 0)
flag1 = 1;
else
flag1 = 0;
}
}
cout << ans << endl;
if(n==1)
{
for (int i = 1; i <= m-1;i++)
{
if(i%2==1)
{
cout << "1 ";
}
else
{
cout << "0 ";
}
}
cout << "1" << endl;
}
else
{
int flag = 1;
for (int i = 1; i <= n; i++)
{
if (i % 2 == 1)
{
if (flag == 1)
{
for (int j = 1; j <= m; j++)
{
if (j % 2 == 1)
{
cout << "1 ";
}
else
{
cout << "0 ";
}
}
cout << endl;
}
if (flag == 0)
{
for (int j = 1; j <= m; j++)
{
if (j % 2 == 0)
{
cout << "1 ";
}
else
{
cout << "0 ";
}
}
cout << endl;
}
if (flag == 1)
flag = 0;
else
flag = 1;
}
else
{
for (int j = 1; j <= m; j++)
{
cout << "0 ";
}
cout << endl;
}
}
}
}
}
else
{
if(n==2&&m==2)
{
cout << 2 << endl;
cout << "1 0" << endl;
cout << "0 1" << endl;
}
else if(n==2&&m%2==0)
{
cout << m / 2 + 1 + 1 << endl;
for (int i = 1; i <= m-1;i++)
{
if(i%2==1)
{
cout << 1 << " ";
}
else
{
cout << 0 << " ";
}
}
cout << 1 << endl;
cout << 1 << " ";
for (int i = 2; i <= m;i++)
{
cout << 0 << " ";
}
}
else
{
long long ans = 0;
int flag1 = 0;
for (int i = 1; i <= n; i+=2)
{
if(m%2==1)
{
if (i % 2 == 1 && flag1 == 0)
{
ans += m / 2 + 1;
}
else if (i % 2 == 1 && flag1 == 1)
{
ans += m / 2;
}
if (flag1 == 0)
flag1 = 1;
else
flag1 = 0;
}
else
{
if (i % 2 == 1 && flag1 == 0)
{
ans += m / 2;
}
else if (i % 2 == 1 && flag1 == 1)
{
ans += m / 2;
}
if (flag1 == 0)
flag1 = 1;
else
flag1 = 0;
}
}
cout << ans+1 << endl;
int flag = 1;
for (int i = 1; i <= n-1; i++)
{
if (i % 2 == 1)
{
if (flag == 1)
{
for (int j = 1; j <= m; j++)
{
if (j % 2 == 1)
{
cout << "1 ";
}
else
{
cout << "0 ";
}
}
cout << endl;
}
if (flag == 0)
{
for (int j = 1; j <= m; j++)
{
if (j % 2 == 0)
{
cout << "1 ";
}
else
{
cout << "0 ";
}
}
cout << endl;
}
if (flag == 1)
flag = 0;
else
flag = 1;
}
else
{
for (int j = 1; j <= m; j++)
{
cout << "0 ";
}
cout << endl;
}
}
cout << "1 ";
for (int i = 1; i <= m - 1;i++)
{
cout << "0 ";
}
cout << endl;
}
}
}
}
详细
Test #1:
score: 100
Accepted
time: 0ms
memory: 3576kb
input:
2 1
output:
2 1 1
result:
ok The answer is correct.
Test #2:
score: 0
Accepted
time: 0ms
memory: 3576kb
input:
3 3
output:
3 1 0 1 0 0 0 0 1 0
result:
ok The answer is correct.
Test #3:
score: -100
Wrong Answer
time: 0ms
memory: 3424kb
input:
1 4
output:
2 1 0 1 1
result:
wrong answer The answer is wrong: expected = 3, found = 2