답안 #72491

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
72491 2018-08-26T08:33:04 Z IDxTree(#2155, TAMREF, imeimi2000, Diuven) 오르막길 (FXCUP3_hill) C++17
32 / 100
1500 ms 42960 KB
#include <bits/stdc++.h>
using namespace std;
typedef pair<int, int> pii;
typedef long long ll;
const int inf=2e9, MX=300010;

struct edge{
	ll x=1, y=0;
	bool operator > (const edge &e) const {
		return y*e.x>e.y*x;
	}
	bool operator == (const edge &e) const {
		return y*e.x==e.y*x;
	}
};

struct node1{
	int idx; edge e;
	bool operator < (const node1 &nd) const {
		return idx<nd.idx;
	}
};

struct node2{
	int idx; edge e;
	bool operator > (const node2 &nd) const {
		return e>nd.e || (e==nd.e && idx>nd.idx);
	}
};

set<node1> S1;
set<node2, greater<node2>> S2;

int n;
ll X[MX], Y[MX];
ll c;

int gcd(int x, int y){
	if(y==0) return x;
	return gcd(y,x%y);
}

ll area(int l, int r){
	return (X[r]-X[l])*(Y[l]+Y[r]);
}

int main(){
scanf("%d%lld", &n, &c);	
c*=2;
	for(int i=1; i<=n; i++) scanf("%lld", &X[i]);
	for(int i=1; i<=n; i++) scanf("%lld", &Y[i]);
	for(int i=1; i<n; i++){
		edge e;
		e.x=X[i+1]-X[i];
		e.y=Y[i+1]-Y[i];
		S1.insert({i,e});
		S2.insert({i,e});
	}
	while(true){
		node2 a=*S2.begin();
		int i=a.idx; edge e=a.e;
		if(i==1) break;

		node1 b=*prev(S1.find({i,e}));
		int j=b.idx; edge f=b.e;

		int k=n;

		auto it=S1.find({i,e});
		if(next(it)!=S1.end()) k=next(it)->idx;

		ll now=area(j,k)-area(j,i)-area(i,k);

		if(now>c) break;

//		cout<<"POINTS: "<<j<<' '<<i<<' '<<k<<'\n';

		c-=now;

		S1.erase({i,e}), S2.erase({i,e});
		S1.erase({j,f}), S2.erase({j,f});

		edge g; g.x=e.x+f.x, g.y=e.y+f.y;
		S1.insert({j,g}), S2.insert({j,g});
//		cout<<S1.size()<<", "<<S2.size()<<'\n';
	}
	{
		edge ans=S2.begin()->e;
		int x=ans.x, y=ans.y, g=gcd(x,y);
printf("%lld/%lld\n", y/g,x/g);
	}
	return 0;
}

Compilation message

hill.cpp: In function 'int main()':
hill.cpp:90:30: warning: format '%lld' expects argument of type 'long long int', but argument 2 has type 'int' [-Wformat=]
 printf("%lld/%lld\n", y/g,x/g);
                       ~~~    ^
hill.cpp:90:30: warning: format '%lld' expects argument of type 'long long int', but argument 3 has type 'int' [-Wformat=]
hill.cpp:48:6: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
 scanf("%d%lld", &n, &c); 
 ~~~~~^~~~~~~~~~~~~~~~~~
hill.cpp:50:31: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  for(int i=1; i<=n; i++) scanf("%lld", &X[i]);
                          ~~~~~^~~~~~~~~~~~~~~
hill.cpp:51:31: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  for(int i=1; i<=n; i++) scanf("%lld", &Y[i]);
                          ~~~~~^~~~~~~~~~~~~~~
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 376 KB Output is correct
2 Correct 4 ms 492 KB Output is correct
3 Correct 3 ms 492 KB Output is correct
4 Correct 4 ms 492 KB Output is correct
5 Correct 3 ms 564 KB Output is correct
6 Correct 5 ms 572 KB Output is correct
7 Correct 3 ms 624 KB Output is correct
8 Correct 4 ms 624 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 376 KB Output is correct
2 Correct 4 ms 492 KB Output is correct
3 Correct 3 ms 492 KB Output is correct
4 Correct 4 ms 492 KB Output is correct
5 Correct 3 ms 564 KB Output is correct
6 Correct 5 ms 572 KB Output is correct
7 Correct 3 ms 624 KB Output is correct
8 Correct 4 ms 624 KB Output is correct
9 Correct 729 ms 42908 KB Output is correct
10 Correct 669 ms 42908 KB Output is correct
11 Execution timed out 1578 ms 42960 KB Time limit exceeded
12 Halted 0 ms 0 KB -