Educational Codeforces Round 107
依然是四题,但是感觉太久没打,好像变得迟钝了。
B题大概就是令
C的话直接暴力维护每种颜色的第一个位置就行,反正只有50个
D的话刚开始没什么想法,构造题什么的真的不会啊
打表之后发现,对于k,在cost为0的情况下,最多能造出长度为
#include<algorithm>
#include<cstdio>
#include<cstring>
#include<vector>
#define fo(i,a,b) for (int (i)=(a);(i)<=(b);(i)++)
#define fd(i,b,a) for (int (i)=(b);(i)>=(a);(i)--)
#define mk(x,y) make_pair((x),(y))
#define A puts("YES")
using namespace std;
typedef long long ll;
const int N=3e5+5;
int n,q;
int t,x,sum,k,ans,len;
int h[50][50];
char a[N];
int b[N];
bool flag;
void dfs(int x){
if (flag) return;
if (x>len){
flag=1;
fo(i,1,n) b[i]=a[i]-'a';
return;
}
fo(i,1,k){
a[x]='a'+i-1;
int z=0;
fo(j,1,x-2) {
if (a[j]==a[x-1] && a[j+1]==a[x]) z++;
}
if (z) continue;
dfs(x+1);
}
}
int main(){
// freopen("data.in","r",stdin);
scanf("%d %d",&n,&k);
len=k*k+1;
dfs(1);
if (n<=len) {
fo(i,1,n) printf("%c",b[i]+'a');
return 0;
}
fo(i,1,len) printf("%c",b[i]+'a');
fo(i,1,len-1) {
h[b[i]][b[i+1]]=1;
}
int id,mn;
fo(i,len+1,n) {
mn=n;
fo(j,0,k-1) {
if (h[b[i-1]][j]<mn){
mn=h[b[i-1]][j];
id=j;
}
}
b[i]=id;
h[b[i-1]][id]++;
}
fo(i,len+1,n) printf("%c",b[i]+'a');
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)