QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#806687#9874. Matrix ConstructionWilliamHu#WA 0ms3748kbC++111.5kb2024-12-09 13:54:592024-12-09 13:55:00

Judging History

你现在查看的是最新测评结果

  • [2024-12-09 13:55:00]
  • 评测
  • 测评结果:WA
  • 用时:0ms
  • 内存:3748kb
  • [2024-12-09 13:54:59]
  • 提交

answer

#include<bits/stdc++.h>
#define int long long
using namespace std;
int read()
{
	int x = 0, f = 1;
	char c = getchar();
	while(c != EOF and !isdigit(c))
	{
		if(c == '-')f = -1;
		c = getchar();
	}
	while(isdigit(c))
	{
		x = x * 10 + c - '0';
		c = getchar();
	}
	return x * f;
}
int n, m, T;
int a[1010][1010];
int ans;

signed main()
{
//	freopen("std.in", "r", stdin);
//	freopen("std.out", "w", stdout);
	T = read();
	while(T --)
	{
		n = read();
		m = read();
		int flag = 0;
		//cout<<n<<' '<<m<<endl;
		if(n % 2 != 0)
		{
			if(m % 2 == 0)
			{
				flag = 1;
				swap(n, m);
			}
			else if(n < m)
			{
				flag = 1;
				swap(n, m);
			}
		}
		else if(n%2==0)
		{
			if(n < m and m % 2 == 0)
			{
				flag = 1;
				swap(n, m);
			}
		}
		cout<<"Yes\n";
		int cnt1 = 0, cnt2 = 0;
		for(int i = 1;i <= (n/2)*2;i ++)
		{
			for(int j = 1;j <= m;j ++)
			{
				if(i % 2 == 0)a[i][j] = 2* (++ cnt2);
				else a[i][j] = 2*(++cnt1)-1;
			}
		}
		if(n % 2 == 1)
		{
			for(int j = 1;j <= m;j ++)
			{
				if(cnt1 * 2 + 1 <= n * m)a[n][j] = 2*(++cnt1)-1;
				else a[n][j] = 2*(++cnt2);
			}
		}
		if(flag)
		{
			for(int i = 1;i <= m;i ++)
			{
				for(int j = 1;j <= n;j ++)
				{
					cout<<a[j][i]<<' ';
				}
				cout<<endl;
			}
		} 
		else
		{
			for(int i = 1;i <= n;i ++)
			{
				for(int j = 1;j <= m;j ++)
				{
					cout<<a[i][j]<<' ';
				}
				cout<<endl;
			}
		}
	}
	return 0;
}
//1 3 5
//2 4 6
//7 9 8

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 0ms
memory: 3620kb

input:

2
1 1
2 3

output:

Yes
1 
Yes
1 3 5 
2 4 6 

result:

ok All test cases passed. (2 test cases)

Test #2:

score: -100
Wrong Answer
time: 0ms
memory: 3748kb

input:

361
4 9
11 12
16 14
3 7
17 13
1 19
12 3
15 19
11 3
8 18
13 10
8 13
9 18
14 11
7 13
6 16
12 13
1 6
11 15
18 19
5 6
17 19
2 3
17 11
16 19
6 14
5 9
7 2
5 11
15 16
3 15
7 11
16 2
19 15
5 19
2 17
13 12
3 5
19 14
6 3
18 2
16 4
6 8
10 9
17 4
5 16
17 9
16 11
6 9
16 5
3 19
18 9
13 9
12 19
6 13
17 15
13 7
12 ...

output:

Yes
1 3 5 7 9 11 13 15 17 
2 4 6 8 10 12 14 16 18 
19 21 23 25 27 29 31 33 35 
20 22 24 26 28 30 32 34 36 
Yes
1 2 23 24 45 46 67 68 89 90 111 112 
3 4 25 26 47 48 69 70 91 92 113 114 
5 6 27 28 49 50 71 72 93 94 115 116 
7 8 29 30 51 52 73 74 95 96 117 118 
9 10 31 32 53 54 75 76 97 98 119 120 
11 ...

result:

wrong answer Duplicate sum found for adjacent elements at (2,1) and (3,1) (test case 3)