Submission #482397

# Submission time Handle Problem Language Result Execution time Memory
482397 2021-10-24T11:48:45 Z MilosMilutinovic Sirni (COCI17_sirni) C++14
84 / 140
1126 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;
	per(i,1,10000000) {
		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])];
			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 45 ms 42688 KB Output is correct
2 Correct 216 ms 90536 KB Output is correct
3 Correct 44 ms 43268 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 47 ms 39628 KB Output is correct
2 Runtime error 950 ms 786436 KB Execution killed with signal 9
3 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 41 ms 42868 KB Output is correct
2 Correct 42 ms 40640 KB Output is correct
3 Correct 43 ms 43052 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 144 ms 66988 KB Output is correct
2 Correct 373 ms 91272 KB Output is correct
3 Correct 222 ms 91164 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 58 ms 43832 KB Output is correct
2 Correct 248 ms 90928 KB Output is correct
3 Correct 141 ms 66092 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 246 ms 91584 KB Output is correct
2 Correct 469 ms 140484 KB Output is correct
3 Correct 176 ms 66648 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 76 ms 46540 KB Output is correct
2 Correct 485 ms 140488 KB Output is correct
3 Correct 200 ms 66648 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 189 ms 75844 KB Output is correct
2 Runtime error 922 ms 786436 KB Execution killed with signal 9
3 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 212 ms 75940 KB Output is correct
2 Runtime error 911 ms 786436 KB Execution killed with signal 9
3 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 67 ms 52740 KB Output is correct
2 Runtime error 1126 ms 786436 KB Execution killed with signal 9
3 Halted 0 ms 0 KB -