QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#462309#7177. Many Many CyclesAlishWA 0ms3788kbC++171.7kb2024-07-03 17:18:182024-07-03 17:18:19

Judging History

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

  • [2024-07-03 17:18:19]
  • 评测
  • 测评结果:WA
  • 用时:0ms
  • 内存:3788kb
  • [2024-07-03 17:18:18]
  • 提交

answer

#include <bits/stdc++.h>

using namespace std;

typedef long long int	ll;
typedef pair<int, int>	pii;
typedef pair<ll, ll>	pll;


#define F		        first
#define S		        second
#define pb		        push_back
#define endl            '\n'
#define Mp              make_pair
#define all(x)          x.begin(), x.end()
#define debug(x)        cerr << #x << " = " << x << endl;
#define fast_io         ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
#define file_io         freopen("tests.in" , "r" , stdin) ;

ll mod = 1e9+7;

const int N = 5e3+23;

vector<pll> g[N];
int h[N], vis[N];
int LCA[N][N];
ll d[N];
vector<pii> be;
vector<int> sub[N];
int n, m;
ll ans=0;

void dfs(int v){
    vis[v]=1;
    sub[v].pb(v);
    LCA[v][v]=v;
    for (auto pp: g[v]){
        ll u=pp.F, w=pp.S;
        if(!vis[u]){
            d[u]=d[v]+w;
            dfs(u);
            for (int vp: sub[v]) for (int up: sub[u]) LCA[up][vp]=LCA[vp][up]=v;
            for (int up: sub[u]) sub[v].pb(up);
            sub[u].clear();
        }
        else if(h[v]<h[u]){
            be.pb({v, u});
            ans=__gcd(ans, w+d[u]-d[v]);

        }
    }
}

int main()
{

    cin>>n>>m;
    for (int i=0; i<m; i++){
        int v, u, w; cin>>v>>u>>w;
        g[v].pb({u, w}); g[u].pb({v, w});
    }
    for (int v=1; v<=n; v++) if(!vis[v]){
        be.clear();
        dfs(v);
        for (int i=0; i<be.size(); i++) for (int j=i+1; j<be.size(); j++){
            pii a=be[i], b=be[j];
            int v=LCA[a.S][b.S];
            int u=a.F;
            if(d[u]<d[b.F]) u=b.F;
            if(d[v]-d[u]>0) ans=__gcd(ans, 2*(d[v]-d[u]));

        }
    }
    cout<<ans<<endl;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 0
Wrong Answer
time: 0ms
memory: 3788kb

input:

4 4
1 2 1
2 3 1
3 4 1
4 1 1

output:

0

result:

wrong answer expected '4', found '0'