QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#793174#9798. Safety FirstLGyxjWA 1291ms12368kbC++202.3kb2024-11-29 17:28:302024-11-29 17:28:33

Judging History

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

  • [2024-11-29 17:28:33]
  • 评测
  • 测评结果:WA
  • 用时:1291ms
  • 内存:12368kb
  • [2024-11-29 17:28:30]
  • 提交

answer

//////////////////////////
// Author: lnyxj
// Time: 2024-11-27 10:48:38
///////////////////////////
#pragma GCC optimize(2)
#pragma GCC optimize(3)
#pragma target("avx,avx2")
// #include <bits/stdc++.h>
#include <algorithm>
#include <iostream>
#include <cstring>
#include <vector>
#define xx first
#define yy second
// #define int long long
// #define double long double
using namespace std;
const int N = 1500 + 4, M = 1e5 + 5, mod = 998244353, inv2 = mod + 1 >> 1, inf = 0x3f3f3f3f;
typedef unsigned long long ull;
typedef pair<int, int> pii;
typedef long long ll;

int T;
int ans[M];
vector<pii> qst[N];

void init() {
	#ifdef LOCALDEBUG
		T = 1;
		qst[2000].push_back({2000, 1});
	#else
		cin >> T;
		for (int i = 1; i <= T; ++ i) {
			int n, m;
			cin >> n >> m;
			if (n == 1) ans[i] = 1;
			else qst[n].push_back({m, i});
		}
	#endif
}

inline void Add(int& x, int y) { ((x += y) >= mod) && (x -= mod); }
// #define Add(x, y) (((x += y) >= mod) && (x -= mod))

void solve() {
	static int f[N][N];
	for (int j = 1; j < N; ++ j) 
		for (int i = j; i < N; ++ i) 
			f[j][i] = 1;
	for (int i = 2; i < N; ++ i) {
		// if (i % 512 == 0) cout << i << '\n' << flush;
		// const int cur = i & 1, las = cur ^ 1;
		// memset(f[cur], 0, sizeof f[cur]);
		for (int k = N - 1; k; -- k) {
			for (int j = N - 1 - k; j >= k; j -= 4) {
				// Add(f[cur][j][k], f[las][j][k]);
				Add(f[k][j + k], f[k][j]);
				Add(f[k][j + k - 1], f[k][j - 1]);
				Add(f[k][j + k - 2], f[k][j - 2]);
				Add(f[k][j + k - 3], f[k][j - 3]);
			}
		}
		for (int k = N - 1; k > 1; -- k) 
			for (int j = N - 1; j >= k; j -= 4) {
				Add(f[k - 1][j], f[k][j]);
				Add(f[k - 1][j - 1], f[k][j - 1]);
				Add(f[k - 1][j - 2], f[k][j - 2]);
				Add(f[k - 1][j - 3], f[k][j - 3]);
			}
		for (auto [m, id] : qst[i]) 
			ans[id] = f[1][m];
		// for (int j = 0; j < qst[i].size(); ++ j) 
			// ans[qst[i][j].yy] = f[1][qst[i][j].xx];
		// for (const pii& a : qst[i]) 
			// ans[a.yy] = f[1][a.xx];
	}
	for (int i = 1; i <= T; ++ i) cout << ans[i] << '\n';
}

signed main() {
	ios::sync_with_stdio(0); cin.tie(0); cout.tie(0);
	#ifdef LOCALDEBUG
		const int t1 = clock();
	#endif
	init(); solve();
	#ifdef LOCALDEBUG
		cerr << clock() - t1 << '\n';
	#endif
	return 0;
}

详细

Test #1:

score: 100
Accepted
time: 1281ms
memory: 12368kb

input:

3
1 3
2 3
3 3

output:

1
4
10

result:

ok 3 number(s): "1 4 10"

Test #2:

score: -100
Wrong Answer
time: 1291ms
memory: 12152kb

input:

1
2000 2000

output:

0

result:

wrong answer 1st numbers differ - expected: '204576309', found: '0'