QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#699068#5. 在线 O(1) 逆元TheZone100 ✓1622ms24376kbC++231.1kb2024-11-02 00:36:182024-11-05 22:07:43

Judging History

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

  • [2024-11-05 22:07:43]
  • 管理员手动重测本题所有提交记录
  • 测评结果:100
  • 用时:1622ms
  • 内存:24376kb
  • [2024-11-02 00:36:18]
  • 评测
  • 测评结果:100
  • 用时:3826ms
  • 内存:24288kb
  • [2024-11-02 00:36:18]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;

using i64 = long long;


struct Inversion { 
	static constexpr int B = (1 << 10), T = (1 << 20);

	int f[T + 5], p[T + 5], buf[T * 3 + 5];
	int *I = buf + T;
	int mod;

	Inversion(int mod_) {
		init(mod_);
	}

	void init(int mod_) {
		mod = mod_;
		for (int u = 1; u <= B; u++) {
			int s = 0, d = (u << 10);
			for (int a = 1; a <= T; a++) {
				if ((s += d) >= mod) s -= mod;
				if (s <= T) {
					if (!f[a]) f[a] = u, p[a] = s;
                    continue;
				} 
                if (s >= mod - T) {
                    if (!f[a]) f[a] = u, p[a] = s - mod;
                    continue;
				} 
                int t = (mod - T - s - 1) / d;
                s += t * d, a += t;
			}
		}

		I[1] = f[0] = 1;
		for (int i = 2; i <= (T << 1); i++) I[i] = 1ll * (mod - mod / i) * I[mod % i] % mod;
		for (int i = -1; i >= -T; i--) I[i] = mod - I[-i];
	}

	int inv(int x) { return 1ll * I[p[x >> 10] + (x & 1023) * f[x >> 10]] * f[x >> 10] % mod; }
};

Inversion inver(998244353);

void init(int p) {
	
}

int inv(int x) {
	return inver.inv(x);
}

详细


Pretests


Final Tests

Test #1:

score: 10
Accepted
time: 26ms
memory: 24176kb

Test #2:

score: 20
Accepted
time: 176ms
memory: 24376kb

Test #3:

score: 30
Accepted
time: 800ms
memory: 24296kb

Test #4:

score: 20
Accepted
time: 1289ms
memory: 24360kb

Test #5:

score: 20
Accepted
time: 1622ms
memory: 24364kb