QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#93461#905. 三元环枚举TimWYZ#AC ✓735ms27428kbC++141.0kb2023-03-31 21:24:542023-03-31 21:24:57

Judging History

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

  • [2023-08-10 23:21:45]
  • System Update: QOJ starts to keep a history of the judgings of all the submissions.
  • [2023-03-31 21:24:57]
  • 评测
  • 测评结果:AC
  • 用时:735ms
  • 内存:27428kb
  • [2023-03-31 21:24:54]
  • 提交

answer

#include <stdio.h>
#include <algorithm>
#include <cstring>
#include <iostream>
#include <unordered_set>
using namespace std;

const int P = 998244353;

inline void add(int &a, const int &b) { a += b; a = (a >= P ? a - P : a); }
inline int aad(const int &a, const int &b) { return (a + b >= P ? a + b - P : a + b); }
inline void mul(int &a, const int &b) { a = 1ll * a * b % P; }
inline int mut(const int &a, const int &b) { return 1ll * a * b % P; }

const int NR = 1e5 + 10;

int n, m;
int a[NR];
int ans = 0;
unordered_set<int> st[NR];

int main()
{
#ifdef WYZ
	freopen("1.in", "r", stdin);
	freopen("1.out", "w", stdout);
#endif
	ios::sync_with_stdio(0);
	
	cin >> n >> m;
	for (int i = 1; i <= n; i++) cin >> a[i];
	for (int i = 1; i <= m; i++) {
		int u, v; cin >> u >> v; u++, v++;
		if (st[u].size() > st[v].size()) swap(u, v);
		int sum = 0;
		for (int t: st[u]) if (st[v].count(t)) add(sum, a[t]);
		add(ans, mut(mut(a[u], a[v]), sum));
		st[u].insert(v), st[v].insert(u);
	}

	cout << ans << '\n';

	return 0;
}

这程序好像有点Bug,我给组数据试试?

詳細信息

Test #1:

score: 100
Accepted
time: 1ms
memory: 8912kb

input:

4 5
1 2 3 4
0 3
2 0
2 1
2 3
1 3

output:

36

result:

ok "36"

Test #2:

score: 0
Accepted
time: 68ms
memory: 15856kb

input:

17707 77101
528756313 434883274 318065816 264440383 659789617 608119380 648104885 725454492 696703871 543030428 663661240 890791532 108201616 428505484 322953840 119811886 691103780 306647414 549862302 176916719 909058872 455464665 307270851 584469329 722629343 875317523 629938577 244419357 78121457...

output:

397965084

result:

ok "397965084"

Test #3:

score: 0
Accepted
time: 27ms
memory: 13676kb

input:

69830 19691
136987924 40280999 438515315 805152546 234164454 129099933 971852321 983937488 410134225 668461222 574343409 885417013 394300887 86086437 570981511 221329455 57893312 584381871 154204049 738660729 728257729 551666498 540440394 165573287 512342480 452470821 669622703 340240729 965382636 9...

output:

0

result:

ok "0"

Test #4:

score: 0
Accepted
time: 62ms
memory: 18176kb

input:

53336 61958
288974909 111681588 291303632 155763712 177741457 164199418 280452914 745629015 727272894 383855815 451963117 263419161 854025925 625817844 903511050 636159790 788165373 442332844 275132246 358996390 239303569 23523747 398318281 935986353 142493592 695297770 499848367 7061287 551242323 6...

output:

906430555

result:

ok "906430555"

Test #5:

score: 0
Accepted
time: 735ms
memory: 16992kb

input:

447 99681
192279220 156648746 154396384 640494892 528756313 434883274 318065816 264440383 659789617 608119380 648104885 725454492 696703871 543030428 663661240 890791532 108201616 428505484 322953840 119811886 691103780 306647414 549862302 176916719 909058872 455464665 307270851 584469329 722629343 ...

output:

687388905

result:

ok "687388905"

Test #6:

score: 0
Accepted
time: 114ms
memory: 25084kb

input:

100000 100000
192279220 156648746 154396384 640494892 528756313 434883274 318065816 264440383 659789617 608119380 648104885 725454492 696703871 543030428 663661240 890791532 108201616 428505484 322953840 119811886 691103780 306647414 549862302 176916719 909058872 455464665 307270851 584469329 722629...

output:

544299331

result:

ok "544299331"

Test #7:

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

input:

100000 100000
264704197 120999146 136987924 40280999 438515315 805152546 234164454 129099933 971852321 983937488 410134225 668461222 574343409 885417013 394300887 86086437 570981511 221329455 57893312 584381871 154204049 738660729 728257729 551666498 540440394 165573287 512342480 452470821 669622703...

output:

173075458

result:

ok "173075458"

Test #8:

score: 0
Accepted
time: 94ms
memory: 24968kb

input:

100000 100000
682152023 451794314 2028037 288974909 111681588 291303632 155763712 177741457 164199418 280452914 745629015 727272894 383855815 451963117 263419161 854025925 625817844 903511050 636159790 788165373 442332844 275132246 358996390 239303569 23523747 398318281 935986353 142493592 695297770...

output:

914677810

result:

ok "914677810"

Test #9:

score: 0
Accepted
time: 0ms
memory: 8852kb

input:

2 1
1 2
0 1

output:

0

result:

ok "0"

Test #10:

score: 0
Accepted
time: 0ms
memory: 8968kb

input:

181 1323
154396384 640494892 528756313 434883274 318065816 264440383 659789617 608119380 648104885 725454492 696703871 543030428 663661240 890791532 108201616 428505484 322953840 119811886 691103780 306647414 549862302 176916719 909058872 455464665 307270851 584469329 722629343 875317523 629938577 2...

output:

810000936

result:

ok "810000936"

Test #11:

score: 0
Accepted
time: 42ms
memory: 10492kb

input:

198 17685
40280999 438515315 805152546 234164454 129099933 971852321 983937488 410134225 668461222 574343409 885417013 394300887 86086437 570981511 221329455 57893312 584381871 154204049 738660729 728257729 551666498 540440394 165573287 512342480 452470821 669622703 340240729 965382636 953292241 144...

output:

893263934

result:

ok "893263934"

Test #12:

score: 0
Accepted
time: 7ms
memory: 9044kb

input:

88 1419
2028037 288974909 111681588 291303632 155763712 177741457 164199418 280452914 745629015 727272894 383855815 451963117 263419161 854025925 625817844 903511050 636159790 788165373 442332844 275132246 358996390 239303569 23523747 398318281 935986353 142493592 695297770 499848367 7061287 5512423...

output:

285141028

result:

ok "285141028"

Test #13:

score: 0
Accepted
time: 1ms
memory: 9008kb

input:

181 299
154396384 640494892 528756313 434883274 318065816 264440383 659789617 608119380 648104885 725454492 696703871 543030428 663661240 890791532 108201616 428505484 322953840 119811886 691103780 306647414 549862302 176916719 909058872 455464665 307270851 584469329 722629343 875317523 629938577 24...

output:

68968143

result:

ok "68968143"

Test #14:

score: 0
Accepted
time: 5ms
memory: 8944kb

input:

198 235
136987924 40280999 438515315 805152546 234164454 129099933 971852321 983937488 410134225 668461222 574343409 885417013 394300887 86086437 570981511 221329455 57893312 584381871 154204049 738660729 728257729 551666498 540440394 165573287 512342480 452470821 669622703 340240729 965382636 95329...

output:

273857930

result:

ok "273857930"

Test #15:

score: 0
Accepted
time: 0ms
memory: 8856kb

input:

88 139
2028037 288974909 111681588 291303632 155763712 177741457 164199418 280452914 745629015 727272894 383855815 451963117 263419161 854025925 625817844 903511050 636159790 788165373 442332844 275132246 358996390 239303569 23523747 398318281 935986353 142493592 695297770 499848367 7061287 55124232...

output:

351774600

result:

ok "351774600"

Test #16:

score: 0
Accepted
time: 104ms
memory: 27416kb

input:

100000 99999
192279220 156648746 154396384 640494892 528756313 434883274 318065816 264440383 659789617 608119380 648104885 725454492 696703871 543030428 663661240 890791532 108201616 428505484 322953840 119811886 691103780 306647414 549862302 176916719 909058872 455464665 307270851 584469329 7226293...

output:

0

result:

ok "0"

Test #17:

score: 0
Accepted
time: 115ms
memory: 27428kb

input:

100000 99999
264704197 120999146 136987924 40280999 438515315 805152546 234164454 129099933 971852321 983937488 410134225 668461222 574343409 885417013 394300887 86086437 570981511 221329455 57893312 584381871 154204049 738660729 728257729 551666498 540440394 165573287 512342480 452470821 669622703 ...

output:

0

result:

ok "0"