QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#865704 | #9678. 网友小 Z 的树 | fzx | 0 | 1ms | 14416kb | C++14 | 3.6kb | 2025-01-21 21:16:02 | 2025-01-21 21:16:03 |
Judging History
answer
#include "diameter.h"
#include <bits/stdc++.h>
#define int long long
#define pii pair<int,int>
#define fi first
#define se second
using namespace std;
const int INF=105;
const int Mod=998244353;
int ksm(int x,int y) {
int ba=x%Mod,ans=1;
while (y) {
if (y&1) ans=(ans*ba)%Mod;
ba=(ba*ba)%Mod;y>>=1;
}
return ans;
}
int g[INF][INF],id[INF][INF],n,tot1,tot2,f[INF];
int ff(int x,int y) {
if (x>y) swap(x,y);
return id[x][y];
}
pii solve() {
memset(g,0,sizeof g);
int tot2=0; tot1=0;
for (int x=1;x<=5;x++)
for (int y=x+1;y<=5;y++)
id[x][y]=++tot2;
for (int x=1;x<=5;x++)
for (int y=x+1;y<=5;y++)
for (int z=y+1;z<=5;z++) {
++tot1;
g[tot1][id[x][y]]=1;
g[tot1][id[x][z]]=1;
g[tot1][id[y][z]]=1;
g[tot1][tot2+1]=query(x,y,z);
}
for (int i=1;i<=tot1;i++) {
int la=i;
for (int j=i+1;j<=tot1;j++)
if (g[j][i]) la=j;
swap(g[i],g[la]);
int t=ksm(g[i][i],Mod-2);
// cerr<<t<<" "<<g[i][i]<<" bomb233\n";
for (int j=1;j<=tot1+1;j++) g[i][j]*=t,g[i][j]%=Mod;
for (int j=i+1;j<=tot1;j++) {
int tt=g[j][i];
for (int k=1;k<=tot1+1;k++)
g[j][k]-=tt*g[i][k],g[j][k]%=Mod;
}
// for (int x=1;x<=tot1;x++) {
// for (int y=1;y<=tot1+1;y++)
// cerr<<g[x][y]<<" ";
// cerr<<" endl233\n";
// }
// cerr<<" print!\n";
}
for (int i=tot1;i;i--) {
g[i][tot1+1]*=ksm(g[i][i],Mod-2);g[i][tot1+1]%=Mod;
for (int j=1;j<i;j++)
g[j][tot1+1]-=g[i][tot1+1]*g[j][i],g[j][tot1+1]%=Mod;
}
// g[1...tot1][tot1+1]
for (int i=1;i<=tot1;i++) f[i]=(g[i][tot1+1]%Mod+Mod)%Mod;
int Max=0,rt1=0,rt2=0,rt3=0;
for (int x=1;x<=5;x++) {
for (int y=x+1;y<=5;y++) {
// cerr<<x<<" "<<y<<" "<<f[id[x][y]]<<" qwq?\n";
if (Max<f[id[x][y]]) {
Max=f[id[x][y]];
// cerr<<x<<" "<<y<<" endl233\n";
for (int z=1;z<=5;z++) {
if (x==z || z==y) continue;
if (f[ff(x,z)]+f[ff(y,z)]==f[ff(x,y)])
rt1=x,rt2=y,rt3=z;
}
}
}
}
// cerr<<rt1<<" "<<rt2<<" "<<rt3<<" endl233\n";
// rt1 -- rt3 --- rt2 rt1->rt2 为 Max
int Max1=f[ff(rt1,rt3)],Max2=f[ff(rt3,rt2)];
for (int u=6;u<=n;u++) {
int it1=query(rt1,rt3,u),it2=query(rt1,rt2,u),it3=query(rt2,rt3,u);
int dd=(it2-Max*2)/2;
// 如果在 rt1 下面就是
// cerr<<dd<<" "<<Max<<" "<<it3<<" qwq?\n";
if (dd*2+Max1*2==it1 && dd*2+Max*2==it3) {
int t1=dd,t2=Max,t3=dd+Max;
Max=t3;Max2=t2;Max1=t1;
rt3=rt1;rt1=u;
}
// 如果在 rt2 下面就是
if (dd*2+Max2*2==it3 && dd*2+Max*2==it1) {
int t1=Max,t2=dd,t3=dd+Max;
Max=t3;Max1=t1;Max2=t2;
rt3=rt2;rt2=u;
}
// 如果两个都不在呢?
if (dd*2+Max2*2<it3) {
// 则在 rt3 左边
// it3/2
if (it3/2>Max) {
Max=it3/2;rt1=u;
Max1=Max-Max2;
}
} else if (dd*2+Max1*2<it1) {
// 则在 rt3 右边
if (it1/2>Max) {
Max=it1/2;rt2=u;
Max2=Max-Max1;
}
} else {
// 则在 rt3 下面
if (it3/2>Max) {
Max=it3/2;rt1=u;
Max1=Max-Max2;
}
}
}
return make_pair(rt1,rt2);
}
std::pair<signed, signed> find_diameter(signed subid, signed N) {
n=N;
if (n==1) return make_pair(1,1);
else if (n==2) return make_pair(1,2);
else {
if (n==3) {
if (in(1,2,3)) return make_pair(2,3);
else if (in(2,1,3)) return make_pair(1,3);
else return make_pair(1,2);
}
if (n==4) {
int Max=0,rt1=0,rt2=0,rt3=0;
for (int x=1;x<=n;x++)
for (int y=x+1;y<=n;y++)
for (int z=y+1;z<=n;z++) {
int kk=query(x,y,z);
if (Max<kk) Max=kk,rt1=x,rt2=y,rt3=z;
}
if (in(rt1,rt2,rt3)) return {rt2,rt3};
else if (in(rt2,rt1,rt3)) return {rt1,rt3};
else return {rt1,rt2};
}
return solve();
}
}
详细
Subtask #1:
score: 0
Wrong Answer
Test #1:
score: 0
Wrong Answer
time: 1ms
memory: 14416kb
input:
1 100 25 1 3 2 18 3 8 4 18 5 14 6 22 7 18 8 10 9 11 10 12 11 25 12 16 13 11 14 17 15 17 16 25 17 2 18 20 19 18 20 12 21 1 22 17 23 14 24 1 50 1 37 2 27 3 10 4 25 5 16 6 17 7 10 8 36 9 16 10 6 11 48 12 2 13 28 14 30 15 10 16 44 17 31 18 1 19 6 20 7 21 30 22 42 23 45 24 23 25 27 26 39 27 45 28 48 29 4...
output:
WA
result:
wrong answer Wrong Answer
Subtask #2:
score: 0
Skipped
Dependency #1:
0%
Subtask #3:
score: 0
Skipped
Dependency #2:
0%
Subtask #4:
score: 0
Skipped
Dependency #3:
0%
Subtask #5:
score: 0
Skipped
Dependency #4:
0%
Subtask #6:
score: 0
Skipped
Dependency #5:
0%
Subtask #7:
score: 0
Skipped
Dependency #6:
0%
Subtask #8:
score: 0
Skipped
Dependency #7:
0%
Subtask #9:
score: 0
Skipped
Dependency #8:
0%
Subtask #10:
score: 0
Skipped
Dependency #9:
0%
Subtask #11:
score: 0
Skipped
Dependency #1:
0%