QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#239483#7688. Alea Iacta Estucup-team2303#WA 1ms3584kbC++142.2kb2023-11-04 20:55:562023-11-04 20:55:57

Judging History

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

  • [2023-11-04 20:55:57]
  • 评测
  • 测评结果:WA
  • 用时:1ms
  • 内存:3584kb
  • [2023-11-04 20:55:56]
  • 提交

answer

/*
60 + 0 + 100 + 64 = 224.
*/

#include <bits/stdc++.h>
using namespace std;
#define int long long
#define L(i, j, k) for (int i = (j); i <= (k); i++)
#define R(i, j, k) for (int i = (j); i >= (k); i--)
#define pb push_back
#define pii pair<int, int>
inline int read()
{
	int sum = 0, nega = 1;
	char ch = getchar();
	while (ch > '9'||ch < '0')
	{
	    if (ch == '-') nega = -1;
		ch = getchar();
	}
	while (ch <= '9' && ch >= '0') sum = sum * 10 + ch - '0', ch = getchar();
	return sum * nega;
}
const int N = 1e6 + 9, mod = 998244353;
inline void add(int &x, int y) {x = (x + y) % mod;}
inline void del(int &x, int y) {x = (x - y + mod) % mod;}
int T, x, y, siz, a, b;
vector<int> G1, G2, F, tmp;
inline void Write(int X)
{
	if(X > 9) Write(X / 10);
	putchar(X % 10 + '0');
}
inline void dfs(int fx, int fy, int fa, int fb, int nw)
{
	if(nw == siz) return ;
	int fac = F[nw];
	if(x % fac != 0 && y % fac != 0) {dfs(fx, fy, fa, fb, nw + 1); return ;}
	if(x % fac != 0) swap(x, y), swap(fx, fy);
	if(a % fac != 0) swap(G1, G2), swap(fa, fb), swap(a, b);
	tmp.clear();
	x /= fac, a /= fac;
	int val = 1;
	L(i, 1, fac)
	{
		for (auto v : G1) tmp.pb(v + val - 1);
		val += fx;
	}
	fx *= fac, fa *= fac; swap(tmp, G1);
	dfs(fx, fy, fa, fb, nw); return ;
}
inline void work()
{
	siz = F.size();
	G1.pb(1); G2.pb(1);
	dfs(1, 1, 1, 1, 0);
	assert(G1.size() + G2.size() <= 3e6);
	Write(G1.size()); putchar(' ');
	for (auto v : G1)
	{
		Write(v); putchar(' ');
	}
	puts("");
	Write(G2.size()); putchar(' ');
	for (auto v : G2)
	{
		Write(v); putchar(' ');
	}
	puts(""); return ;
}
inline void solve()
{
	x = read(), y = read();
	int t = x * y, f = sqrt(t);
	G1.clear(), G2.clear(); F.clear(); siz = F.size();
	int ff = t;
	L(i, 2, f)
		if(ff % i == 0)
		{
			F.pb(i);
			while(ff % i == 0) ff /= i;
		}
	if(ff != 1)
	{
		if(ff == t) {puts("0"); puts("0"); return ;}
		F.pb(ff);
	}
	R(i, f, 1)
	{
		if(t % i != 0) continue;
		a = i, b = t / i;
		if(a == x || a == y) continue;
		if(a+b>6e6)
		{
			puts("0"); puts("0");return;
		}
		work(); return ;
	}
	puts("0"); puts("0");
	return ;
}
signed main()
{
	T = read();
	L(i, 1, T) solve();
	return 0;
}



Details

Tip: Click on the bar to expand more detailed information

Test #1:

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

input:

3
2 8
1 9
2 9

output:

4 1 3 5 7 
4 1 2 2 3 
3 1 4 7 
3 1 2 3 
3 1 4 7 
6 1 2 2 3 3 4 

result:

ok Correct. (3 test cases)

Test #2:

score: -100
Wrong Answer
time: 1ms
memory: 3392kb

input:

1
40013 40013

output:

0
0

result:

wrong answer Integer parameter [name=n1] equals to 0, violates the range [1, 120039] (test case 1)