Submission #275649

# Submission time Handle Problem Language Result Execution time Memory
275649 2020-08-20T06:53:27 Z 최은수(#5098) Happiness (Balkan15_HAPPINESS) C++17
60 / 100
2000 ms 297624 KB
#include"happiness.h"
#include<iostream>
#include<vector>
#include<unordered_map>
#include<algorithm>
#define ep emplace
#define eb emplace_back
#define fi first
#define se second
#define all(x) (x).begin(),(x).end()
using namespace std;
typedef long long ll;
typedef pair<int,int>pi;
typedef pair<ll,ll>pl;
const int inf=1e9+7;
const ll INF=1e18;
struct seg
{
	struct node
	{
		ll v,lz;
		int l,r;
		node(){v=lz=0,l=r=0;}
	}st[12000010];
	int tct;
	int rt;
	seg(){rt=tct=0;}
	void upd(int&n,ll s,ll e,ll S,ll E,ll p)
	{
		if(s>E||S>e)
			return;
		if(n==0)
			n=++tct;
		if(S<=s&&e<=E)
		{
			st[n].v+=p;
			st[n].lz+=p;
			return;
		}
		ll m=s+(e-s)/2;
		upd(st[n].l,s,m,S,E,p);
		upd(st[n].r,m+1,e,S,E,p);
		st[n].v=min(st[st[n].l].v,st[st[n].r].v)+st[n].lz;
		return;
	}
}st;
ll m;
unordered_map<ll,int>mp;
bool init(int coinsCount,ll maxCoinSize,ll coins[])
{
	m=maxCoinSize;
	int n=coinsCount;
	for(int i=0;i<n;i++)
	{
		ll t=coins[i];
		if(mp[t]++==0)
			st.upd(st.rt,1,m,t,t,-t);
		if(t<m)
			st.upd(st.rt,1,m,t+1,m,t);
	}
	return st.st[st.rt].v>=-1;
}
bool is_happy(int event,int coinsCount,ll coins[])
{
	int n=coinsCount;
	if(event==1)
	{
		for(int i=0;i<n;i++)
		{
			ll t=coins[i];
			if(mp[t]++==0)
				st.upd(st.rt,1,m,t,t,-t);
			if(t<m)
				st.upd(st.rt,1,m,t+1,m,t);
		}
	}
	else
	{
		for(int i=0;i<n;i++)
		{
			ll t=coins[i];
			if(--mp[t]==0)
				st.upd(st.rt,1,m,t,t,t);
			if(t<m)
				st.upd(st.rt,1,m,t+1,m,-t);
		}
	}
	return st.st[st.rt].v>=-1;
}

Compilation message

grader.cpp: In function 'int main()':
grader.cpp:16:12: warning: unused variable 'max_code' [-Wunused-variable]
   16 |  long long max_code;
      |            ^~~~~~~~
# Verdict Execution time Memory Grader output
1 Correct 187 ms 282104 KB Output is correct
2 Correct 174 ms 282104 KB Output is correct
3 Correct 175 ms 282232 KB Output is correct
4 Correct 170 ms 282104 KB Output is correct
5 Correct 173 ms 282360 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 187 ms 282104 KB Output is correct
2 Correct 174 ms 282104 KB Output is correct
3 Correct 175 ms 282232 KB Output is correct
4 Correct 170 ms 282104 KB Output is correct
5 Correct 173 ms 282360 KB Output is correct
6 Correct 178 ms 282148 KB Output is correct
7 Correct 191 ms 282104 KB Output is correct
8 Correct 212 ms 282744 KB Output is correct
9 Correct 203 ms 282744 KB Output is correct
10 Correct 202 ms 282616 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 187 ms 282104 KB Output is correct
2 Correct 174 ms 282104 KB Output is correct
3 Correct 175 ms 282232 KB Output is correct
4 Correct 170 ms 282104 KB Output is correct
5 Correct 173 ms 282360 KB Output is correct
6 Correct 900 ms 290796 KB Output is correct
7 Correct 889 ms 290620 KB Output is correct
8 Correct 959 ms 290888 KB Output is correct
9 Correct 1573 ms 297244 KB Output is correct
10 Correct 1447 ms 297148 KB Output is correct
11 Correct 673 ms 297444 KB Output is correct
12 Correct 704 ms 297444 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 187 ms 282104 KB Output is correct
2 Correct 174 ms 282104 KB Output is correct
3 Correct 175 ms 282232 KB Output is correct
4 Correct 170 ms 282104 KB Output is correct
5 Correct 173 ms 282360 KB Output is correct
6 Correct 178 ms 282148 KB Output is correct
7 Correct 191 ms 282104 KB Output is correct
8 Correct 212 ms 282744 KB Output is correct
9 Correct 203 ms 282744 KB Output is correct
10 Correct 202 ms 282616 KB Output is correct
11 Correct 900 ms 290796 KB Output is correct
12 Correct 889 ms 290620 KB Output is correct
13 Correct 959 ms 290888 KB Output is correct
14 Correct 1573 ms 297244 KB Output is correct
15 Correct 1447 ms 297148 KB Output is correct
16 Correct 673 ms 297444 KB Output is correct
17 Correct 704 ms 297444 KB Output is correct
18 Correct 1473 ms 291516 KB Output is correct
19 Correct 1444 ms 291884 KB Output is correct
20 Execution timed out 2094 ms 297624 KB Time limit exceeded
21 Halted 0 ms 0 KB -