acwing第 48 场周赛

目录

  • 4410. 吃鸡蛋
  • 4411. 三仙归洞
  • 4412. 构造数组

4410. 吃鸡蛋

题目链接:土鸡蛋

#include 
using namespace std;
int n,m;
int main()
{
	cin>>n>>m;
	int cnt=n;
	int day=1;
	while(cnt)
	{
		cnt--;
		if(day>=m&&day%m==0)cnt++;
		day++;
	}
	cout<<day-1<<endl;
	return 0;
}

4411. 三仙归洞

题目链接:三仙归洞

#include 
using namespace std;
int n,x;
int main()
{
	cin>>n>>x;
    int a[6][3]={{0,1,2},{1,0,2},{1,2,0},{2,1,0},{2,0,1},{0,2,1}};
    cout<<a[n%6][x]<<endl;
	return 0;
}

4412. 构造数组

题目链接:构造数组
哈希+合并区间

#include 
#define x first
#define y second
using namespace std;
const int mod=998244353;
const int N=200010;
typedef pair<int,int>PII;
int n;
PII q[N];
int main()
{
	cin>>n;
	unordered_map<int,int>L(300000),R(300000);
	for(int i=1;i<=n;i++)
	{
		int a;
		cin>>a;
		R[a]=i;
		if(!L.count(a))L[a]=i;
	}
	int m=0;
	for(auto &[k,v]:L)q[m++]={L[k],R[k]};
	sort(q,q+m);
	int cnt=0,st=-1,ed=-1;
	for(int i=0;i<m;i++)
	{
		if(ed<q[i].x)
		{
			if(ed!=-1)cnt++;
			st=q[i].x,ed=q[i].y;
		}
		else if(ed<q[i].y)
			ed=q[i].y;
	}
	if(st!=-1)cnt++;
	int res=1;
	for(int i=0;i<cnt-1;i++)
	{
		res=res*2%mod;
	}
	cout<<res<<endl;
	return 0;
}

你可能感兴趣的:(C++,算法,AcWing周赛,c++,算法)