#include<cstdio>
#include<cstring>
using namespace std;
int n,L;
int cnt=0;
int S[80];
int flag=0;
int dfs(int cur){
if(cnt++ == n){
for(int i=0;i<cur;i++) { if(i%4==0&&i!=0) printf(" ");printf("%c",S[i]+'A'); } printf("\n%d\n",cur);
return 0;
}
else for(int i=0;i<L;i++)
if(!flag)
{
S[cur]=i;
int ok=1;
for(int j=1;j*2<=cur+1;j++){
int mark=1;
for(int k=0;k<j;k++)
if(S[cur-k]!=S[cur-k-j]) { mark=0; break; }
if(mark) { ok=0; break; }
}
if(ok) if( !dfs(cur+1) ) return 0;
}
// printf("dsa\n");
return 1;
}
int main(){
while(~scanf("%d%d",&n,&L)&&n&&L)
{
flag=0;
cnt=0;
dfs(0);
}
return 0;
}
uva129
最新推荐文章于 2021-03-14 14:19:05 发布