4410. 吃鸡蛋
题目链接:土鸡蛋
#include <bits/stdc++.h>
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 <bits/stdc++.h>
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 <bits/stdc++.h>
#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;
}
|