# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
887157 | Servant_of_the_Lord | Sirni (COCI17_sirni) | C++17 | 5049 ms | 608848 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
#pragma GCC optimize("O3")
#pragma GCC target("avx,avx2,sse4")
#define ll long long
using namespace std;
main()
{
ios_base::sync_with_stdio(false);
cin.tie(0);
ll x,y,z,a,b,c;
cin>>x;
set<pair<ll,ll>>s;
for(ll i=0;i<x;i++)
{
cin>>y;
s.insert({y,i});
}
vector<vector<ll>>v(10'000'000);
for(pair<ll,ll> i:s)
{
if(v[i.first-1].empty())
{
for(ll j=i.first-1;j<10'000'000;j+=i.first)
{
v[j].push_back(i.second);
}
}
}
vector<ll>w(x,-1);
function<ll(ll)>g=[&](ll a){return w[a]<0?a:w[a]=g(w[a]);};
function<bool(ll,ll)>u=[&](ll a,ll b)
{
a=g(a),b=g(b);
if(a==b)return false;
if(w[a]>w[b])swap(a,b);
w[a]+=w[b];
w[b]=a;
return true;
};
a=0;
bitset<10'000'000>t;
for(ll i=0;i<10'000'000;i++)
{
vector<pair<ll,ll>>e;
for(pair<ll,ll> j:s)
{
for(ll k=0;k<v[j.first-i-1].size();k++)
{
if(u(j.second,v[j.first-i-1][k]))
{
a+=i;
}
}
if(j.first-i-1==0||t[j.first-i-1])e.push_back(j);
t[j.first-i-1]=1;
}
for(auto j:e)s.erase(j);
if(s.empty())break;
}
cout<<a<<'\n';
}
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |