99632024-03-21 19:30:40111Erőművekcpp17Hibás válasz 76/100263ms77316 KiB
#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
using namespace std;
using namespace __gnu_pbds;

template<typename T>
using ordered_set = tree<T, null_type, less_equal<T>, rb_tree_tag, tree_order_statistics_node_update>;

#define int long long

#define INF (int)1e18

signed main() {
	ios::sync_with_stdio(0);
	cin.tie(0);
#ifdef CB
	freopen("be2.txt","r",stdin);
//	freopen("out.txt","w",stdout);
#endif
	int N,M;
	cin>>N>>M;
	vector<int>v(N+1);
	int su=0;
	for(int i=1;i<=N;i++){
		cin>>v[i];
		su+=v[i];
	}
	vector<vector<int>>g(N+1);
	for(int i=0;i<M;i++){
		int a,b;
		cin>>a>>b;
		g[a].push_back(b);
		g[b].push_back(a);
	}
	int ans=INF;
	int ans1=0;
	int ans2=0;
	vector<int>l(N+1,INF),a(N+1,0);
	vector<int>s(N+1);
	vector<ordered_set<int>>z(N+1);
	auto dfs=[&](auto self,int i)->void{
		for(int j:g[i]){
			if(l[j]==l[i]-1){
				continue;
			}
			if(l[j]!=INF){
				if(l[j]<l[a[i]]){
					a[i]=j;
				}
				continue;
			}
			l[j]=l[i]+1;
			self(self,j);
			s[i]+=s[j];
			if(l[a[j]]<l[a[i]]){
				a[i]=a[j];
			}
			if(l[a[j]]>l[i]){
				z[j].insert(s[j]);
				int s1=su-s[j],s2,s3;
				auto f=[&](){
					ans1=max({s1,s2,s3})-min({s1,s2,s3});
					if(ans1<ans){
						ans=ans1;
						ans2=0;
					}
				};
				auto it=z[j].upper_bound(s[j]/2);
				if(it!=z[j].end()){
					s2=*it;
					s3=su-s1-s2;
					f();
				}
				if(it!=z[j].begin()){
					--it;
					s2=*it;
					s3=su-s1-s2;
					f();
				}
				if(!z[j].empty()){
					s2=*s.begin();
					s3=su-s1-s2;
					f();
					s2=*--s.end();
					s3=su-s1-s2;
					f();
				}
				int ll=max({s1-ans,su-s1-(s1+ans),(su-s1-ans)/2});
				int hh=min({s1+ans,su-s1-(s1-ans),(su-s1+ans)/2});
				if(ll<=hh){
					ans2+=z[j].order_of_key(hh+1)-z[j].order_of_key(ll);
				}
			}
			if(z[j].size()>z[i].size()){
				swap(z[i],z[j]);
			}
			int x=-1,xx=0;
			for(int s1:z[j]){
				if(s1==x){
					ans2+=xx;
					continue;
				}
				x=s1;
				xx=0;
				int s2,s3;
				auto f=[&](){
					ans1=max({s1,s2,s3})-min({s1,s2,s3});
					if(ans1<ans){
						ans=ans1;
						ans2=0;
					}
				};
				auto it=z[i].upper_bound(s[i]/2);
				if(it!=z[i].end()){
					s2=*it;
					s3=su-s1-s2;
					f();
				}
				if(it!=z[i].begin()){
					--it;
					s2=*it;
					s3=su-s1-s2;
					f();
				}
				if(!z[i].empty()){
					s2=*s.begin();
					s3=su-s1-s2;
					f();
					s2=*--s.end();
					s3=su-s1-s2;
					f();
				}
				int ll=max({s1-ans,su-s1-(s1+ans),(su-s1-ans)/2});
				int hh=min({s1+ans,su-s1-(s1-ans),(su-s1+ans)/2});
				if(ll<=hh){
					ans2+=xx=z[i].order_of_key(hh+1)-z[i].order_of_key(ll);
				}
			}
			for(int k:z[j]){
				z[i].insert(k);
			}
		}
		s[i]+=v[i];
	};
	l[1]=0;
	dfs(dfs,1);
	cout<<ans<<'\n';
	cout<<ans2<<'\n';
	return 0;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base76/100
1Hibás válasz0/03ms1888 KiB
2Elfogadva0/07ms4032 KiB
3Elfogadva5/54ms2936 KiB
4Elfogadva5/53ms2904 KiB
5Elfogadva5/54ms3616 KiB
6Elfogadva5/54ms3500 KiB
7Elfogadva5/516ms6648 KiB
8Elfogadva5/510ms6184 KiB
9Elfogadva5/534ms12368 KiB
10Elfogadva5/519ms10112 KiB
11Elfogadva6/697ms30964 KiB
12Elfogadva6/652ms23516 KiB
13Elfogadva6/6177ms54196 KiB
14Elfogadva6/696ms38328 KiB
15Időlimit túllépés0/6257ms77316 KiB
16Elfogadva6/6159ms53324 KiB
17Időlimit túllépés0/6263ms44272 KiB
18Elfogadva6/6184ms64964 KiB
19Időlimit túllépés0/6224ms43784 KiB
20Időlimit túllépés0/6224ms74064 KiB