首页 > 其他分享 >2023-2024 ICPC, NERC, Northern Eurasia Onsite镜像赛瞎写

2023-2024 ICPC, NERC, Northern Eurasia Onsite镜像赛瞎写

时间:2023-12-13 20:55:58浏览次数:44  
标签:Onsite Eurasia ch Northern int long pair while 序列

晚饭吃的卷饼,好吃。

L

题意

有 \(n\) 个字符,L 代表面包,O 代表洋葱,你和一个朋友需要分这些食物,需满足以下要求:

  1. 每个人至少有一件物品。
  2. 你从最左边向右边连续取,剩下的都是那个朋友的。
  3. 你们的面包数和洋葱数不能相同。

输出一个方案你分得的物品数,如无解则输出 \(-1\)。

做法

感觉是最简单的,\(n\) 居然在 \(2e2\) 范围内。

如果面包数 \(L\) 是偶数,\(loc_i\) 代表第 \(i\) 个面包的位置,则区间 \(\left[loc_{\frac{L}{2}},loc_{\frac{L}{2}+1}\right]\) 中的数不能选择。
奇数不用考虑。

洋葱同理。

然后看一下这个两个区间的并的补是否是空集,输出就可以了。

#include<bits/stdc++.h>
//#define tests 1
//#define open freopen(".in","r",stdin);freopen(".out","w",stdout);
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
const int MAXN=2e2+10;
int n,L,O,locl[MAXN],loco[MAXN];
char item[MAXN];
bool flag[MAXN];
int read(){
	int x=0;
	char ch=getchar();
	while(ch<'0'||ch>'9'){ch=getchar();}
	while(ch>='0'&&ch<='9'){x=x*10+(ch^48);ch=getchar();}
	return x;
}
namespace sol{
	void solve(){
		n=read();
		do{
			item[1]=getchar();
		}while(item[1]!='L'&&item[1]!='O');
		if(item[1]=='L')locl[++L]=1;
		else loco[++O]=1;
		for(int i=2;i<=n;++i){
			item[i]=getchar();
			if(item[i]=='L')locl[++L]=i;
			else loco[++O]=i;
		}
		if((~L)&1){
//			cerr<<"debug1\n";
//			cerr<<(L>>1)<<' '<<(L>>1|1)<<'\n';
			for(int i=locl[L>>1];i<locl[(L>>1)+1];++i){
				flag[i]=1;
			}
		}
		if((~O)&1){
//			cerr<<"debug2\n";
			for(int i=loco[O>>1];i<loco[(O>>1)+1];++i){
				flag[i]=1;
			}
		}
		bool ansflag=false;
		for(int i=1;i<n;++i){
			if(!flag[i]){
				printf("%d\n",i);
				ansflag=true;
				break;
			}
		}
		if(!ansflag)puts("-1");
	}
}
int main(){
	sol::solve();
	return 0;
}

A

做这题的时候被迫变量名改成了同学名。

题意

给定 \(x\),\(k\),有 \(k\) 个序列,每个序列在开头的数 \(n_i\) 代表接下来这个序列有多少个数,你可以对每个序列从开头的数(不含 \(n_i\))向后面与 \(x\) 做加操作,期间 \(x\) 不能为 \(0\),可以先加其他序列的数再回到某序列上继续加。

做法

贪心题。

很明显如果有一段正数需要把正数全加上,那么序列就会被分成前导负数后正数的好几段,相当于 \(x\) 多大的前提下将 \(x\) 加上多少。

直接分出的段可能有负的,所以需要把前面的负的段和后面正的段合成一段来看。
注意这个代价是取左起子序列最小值。

将其代价排序后累加至不能相加即可。
不能够直接进行排序,因为需要将前面所有的数都加完后才能加后面的数,正确的做法应该是一开始取开头的一段入堆,然后不断取出累加,同序列中后面的一段入堆,直到不能相加为止。

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
const int MAXK=1e5+10;
int k,n;
ll x,tsum,tdaijia;
vector<pair<ll,ll> > a[MAXK];
priority_queue<pair<pair<ll,ll>,pair<int,int> > > q;/*小根堆,所以第一个元素负数*/
int read(){
	int f=1,x=0;
	char ch=getchar();
	while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
	while(ch>='0'&&ch<='9'){x=x*10+(ch^48);ch=getchar();}
	return f*x;
}
namespace sol{
	void solve(){
		x=read();k=read();
		for(int i=1;i<=k;++i){
			n=read();
			ll daiji=0,su=0;
			bool pos=false;
			for(int j=1,temp;j<=n;++j){
				temp=read(); 
				if(temp<=0){
					if(pos){
						pos=false;
						if(su<=0){
							su+=temp;
							daiji=min(su,daiji);
						}else{
							a[i].push_back(make_pair(daiji,su));
							daiji=su=temp;
						}
					}else{
						su+=temp;
						daiji=min(daiji,su);
					}
				}else{
					su+=temp;
					pos=true;
				}
			}
			if(pos&&su>0){
				a[i].push_back(make_pair(daiji,su));
			}
			if(a[i].size())q.push(make_pair(a[i][0],make_pair(i,0)));
		}
		while(!q.empty()&&x+q.top().first.first>=0){
			pair<pair<ll,ll>,pair<int,int> >temp=q.top();q.pop();
			x+=temp.first.second;
			if(temp.second.second+1<a[temp.second.first].size()){
				q.push(make_pair(a[temp.second.first][temp.second.second+1],make_pair(temp.second.first,temp.second.second+1)));
			}
		}
		printf("%lld\n",x);
	}
}
int main(){
	sol::solve();
	return 0;
}

K

题意

给定一个长度为 \(N\) 的数列 \(a\) ,求有多少个数的数量大于等于三且数相加为偶数的组合。

做法

很明显组合的结构只能是偶数个奇数任意个偶数

对奇数和偶数进行统计,然后用柿子算出来即可。

设奇数总数为 \(tot_1\),偶数总数为 \(tot_2\)。

标签:Onsite,Eurasia,ch,Northern,int,long,pair,while,序列
From: https://www.cnblogs.com/LiJoQiao/p/17899894.html

相关文章

  • 2019-2020 ICPC, NERC, Northern Eurasia Finals
    组队打\(\rmICPC\),队友是\(\rmfishead\)和\(\rmLiang_Yusong\)。只过了五个题,还是太菜了。开局\(6\min\)我先把\(\rmB\)切了,然后\(\rmLYS\)在\(34\min\)时过了\(\rmE\)。这个时候\(\rmfishead\)切\(\rmL\),做法假了,罚时\(++\)。然后我开\(\rmD\),......
  • The 2021 CCPC Guilin Onsite (XXII Open Cup, Grand Prix of EDG)
    Preface昨天下午16:30~21:30刚打完CCPC2021的广州,今天早上九点又开始打这场桂林,压力拉满了属于是这场比起昨天那场良心太多了,开场还挺顺(虽然因为写Dijkstra偷懒TLE了四发),但开题啥的都是见一个会一个中期虽然有点卡但因为祁神会了几何所以没有空机,然后再点完外卖后我突然顿悟把BK......
  • The 2nd Universal Cup. Stage 5: Northern J Sets May Be Good
    题解我们考虑计算\(\sum_{S\subseteq\{1,2,3,\cdots,n\}}(-1)^{cnt(S)}\),这里\(cnt(S)\)表示\(S\)集合的导出子图的边数。我们记\(x_i=[i\inS]\)。我们考虑删掉\(n\)号点。注意到如果\(x_i\)的取值会影响\(cnt(s)\)的奇偶性,则正负相消,贡献为\(0\)。所以我们需......
  • The 2021 CCPC Weihai Onsite
    Preface又被打爆了,看了下榜这场罚时比较炸喜提银首咯不过yysy这场题出的还是挺好的,medium题都挺有意思需要想一想但就是感觉考的组合计数这一块有点太多了,而且因为有人歪榜开局过了M,导致我前期一直在这道题上坐牢,最后还是徐神出马一套生成函数秒了此题A.Goodbye,Ziyin!签......
  • 2022 China Collegiate Programming Contest (CCPC) Mianyang Onsite
    2022ChinaCollegiateProgrammingContest(CCPC)MianyangOnsiteC.CatchYouCatchMe解题思路:站在距离出口最近的点等深度深的蝴蝶飞上来即可。时间复杂度:\(O(n)\)代码:#include<bits/stdc++.h>usingnamespacestd;usingll=longlong;voidsolve(){ intn......
  • 2022 China Collegiate Programming Contest (CCPC) Guangzhou Onsite
    Preface好难啊这场广州站,不愧是5题金4题铜的超恶劣站,中档题普遍难度较高但我感觉主要原因还是题目出的太偏向于DP了,AI是本质差不多的树上换根DP,M又是个数位DP,导致像我这种不擅长DP的人直接中期坐牢但好在祁神大力切出了medium~hard的K题,然后最后一小时我把一直在想的A题丢给徐......
  • 2022 China Collegiate Programming Contest (CCPC) Mianyang Onsite
    Preface久违地VP一场,由于CCPC桂林在即因此最近就自主VP一下去年的CCPC这场打的时候全队不在状态,签完到后我就因为A题一个cornercase没考虑到卡了快两个小时然后好不容易搞过去徐神上来有狂WAE题,最后也是喜提+11后面写的D题也是需要特判,好家伙又是快到比赛结束才看出来最后......
  • 2022 China Collegiate Programming Contest (CCPC) Mianyang Onsite GCHMAD
    2022ChinaCollegiateProgrammingContest(CCPC)MianyangOnsite目录2022ChinaCollegiateProgrammingContest(CCPC)MianyangOnsiteVP情况G-LetThemEatCakeC-CatchYouCatchMeH-LifeisHardandUndecidable,but...M-Rock-Paper-ScissorsPyramidA-......
  • 2022 China Collegiate Programming Contest (CCPC) Mianyang Onsite (2022CCPC绵阳)ACG
    2022ChinaCollegiateProgrammingContest(CCPC)MianyangOnsite(2022CCPC绵阳)ACGHMhttps://codeforces.com/gym/104065昨天女队vp了一下,赛时4题223罚时A是一个dp,学妹已经写的差不多了,就是转移方向错了(给点时间应该能d出来)牛的牛的。我就看了点签到,又是作为蟑螂乱爬的一天......
  • The 16-th BIT Campus Programming Contest - Onsite Round
    链接:https://codeforces.com/gym/104025A.Giftsinbox#include"bits/stdc++.h"usingnamespacestd;usingi64=longlong;intmain(){ios::sync_with_stdio(false);cin.tie(nullptr);intn,m,h;cin>>n>>m>&......