Submission #482447

# Submission time Handle Problem Language Result Execution time Memory
482447 2021-10-24T15:16:52 Z MilosMilutinovic Sirni (COCI17_sirni) C++14
84 / 140
1118 ms 786436 KB
#include <bits/stdc++.h>
using namespace std;
#define rep(i,a,n) for (int i=a;i<n;i++)
#define per(i,a,n) for (int i=n-1;i>=a;i--)
#define pb push_back
#define mp make_pair
#define all(x) (x).begin(),(x).end()
#define fi first
#define se second
#define SZ(x) ((int)(x).size())
typedef vector<int> VI;
typedef long long ll;
typedef pair<int,int> PII;
typedef double db;
mt19937 mrand(random_device{}());
const ll mod=1000000007;
int rnd(int x) { return mrand() % x;}
ll powmod(ll a,ll b) {ll res=1;a%=mod; assert(b>=0); for(;b;b>>=1){if(b&1)res=res*a%mod;a=a*a%mod;}return res;}
ll gcd(ll a,ll b) { return b?gcd(b,a%b):a;}
// head

const int N=101000;
int n,_[N],a[N],id[10000005],f[N];
int find(int x){
	return f[x]==x?x:f[x]=find(f[x]);
}
struct edge{
	int u,v,w;
	bool operator<(const edge oth) const{return w<oth.w;}
};
vector<edge> ed;
bool x[10000005];
int main() {
	scanf("%d",&n);
	rep(i,0,n) f[i]=i;
	rep(i,0,n) scanf("%d",_+i),x[_[i]]=true;
	sort(_,_+n);
	int nxt=0;
	rep(i,0,n) if (i==0||_[i]!=_[i-1]) a[nxt++]=_[i]; n=nxt;
	int pos=n-1;
	id[10000002]=0;
	per(i,1,10000002) {
		if (x[i]) id[i]=pos,pos--;
		else id[i]=id[i+1];
	}
	rep(i,0,n) {
		for (int j=a[i];j<=a[n-1];j+=a[i]) {
			int x=id[j+(j==a[i]?1:0)];
			ed.pb({i,x,a[x]%a[i]});
		}
	}
	sort(all(ed));
	ll ans=0;
	for (auto e:ed) {
		int x=find(e.u);
		int y=find(e.v);
		if (x!=y) {
			ans+=e.w;
			f[x]=y;
		}
	}
	printf("%lld",ans);
}

Compilation message

sirni.cpp: In function 'int main()':
sirni.cpp:3:20: warning: this 'for' clause does not guard... [-Wmisleading-indentation]
    3 | #define rep(i,a,n) for (int i=a;i<n;i++)
      |                    ^~~
sirni.cpp:39:2: note: in expansion of macro 'rep'
   39 |  rep(i,0,n) if (i==0||_[i]!=_[i-1]) a[nxt++]=_[i]; n=nxt;
      |  ^~~
sirni.cpp:39:52: note: ...this statement, but the latter is misleadingly indented as if it were guarded by the 'for'
   39 |  rep(i,0,n) if (i==0||_[i]!=_[i-1]) a[nxt++]=_[i]; n=nxt;
      |                                                    ^
sirni.cpp:34:7: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   34 |  scanf("%d",&n);
      |  ~~~~~^~~~~~~~~
sirni.cpp:36:18: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   36 |  rep(i,0,n) scanf("%d",_+i),x[_[i]]=true;
      |             ~~~~~^~~~~~~~~~
# Verdict Execution time Memory Grader output
1 Correct 41 ms 42684 KB Output is correct
2 Correct 219 ms 90540 KB Output is correct
3 Correct 42 ms 43168 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 44 ms 39620 KB Output is correct
2 Runtime error 1038 ms 786436 KB Execution killed with signal 9
3 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 44 ms 42948 KB Output is correct
2 Correct 40 ms 40584 KB Output is correct
3 Correct 42 ms 43000 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 161 ms 66596 KB Output is correct
2 Correct 353 ms 91384 KB Output is correct
3 Correct 196 ms 91512 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 60 ms 43816 KB Output is correct
2 Correct 245 ms 90992 KB Output is correct
3 Correct 141 ms 66316 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 279 ms 91192 KB Output is correct
2 Correct 472 ms 140764 KB Output is correct
3 Correct 167 ms 66892 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 71 ms 46536 KB Output is correct
2 Correct 483 ms 140628 KB Output is correct
3 Correct 179 ms 66860 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 188 ms 75396 KB Output is correct
2 Runtime error 902 ms 786436 KB Execution killed with signal 9
3 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 211 ms 75492 KB Output is correct
2 Runtime error 919 ms 786436 KB Execution killed with signal 9
3 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 73 ms 52696 KB Output is correct
2 Runtime error 1118 ms 786436 KB Execution killed with signal 9
3 Halted 0 ms 0 KB -