我自己尝试编码并且非常失败.这基本上就是我想要的:
a
b
...
z
aa
ba
...
za
ab
bb
...
zz
aaa
baa
...
zzz
Run Code Online (Sandbox Code Playgroud)
最后它应该生成每个字符串,使用charset az生成短于N个字符的字符串.所以我不是在寻找排列(在互联网上可以找到1001个实现),但是对于替换组合(至少在Python中它是如何调用的).订单并不重要,速度是.
Jul*_*éon 10
看起来你想要它在C中,这是一种方法:
#include <stdlib.h>
#include <stdio.h>
int inc(char *c){
if(c[0]==0) return 0;
if(c[0]=='z'){
c[0]='a';
return inc(c+sizeof(char));
}
c[0]++;
return 1;
}
int main(void){
int n = 3;
int i,j;
char *c = malloc((n+1)*sizeof(char));
for(i=1;i<=n;i++){
for(j=0;j<i;j++) c[j]='a';
c[i]=0;
do {
printf("%s\n",c);
} while(inc(c));
}
free(c);
}
Run Code Online (Sandbox Code Playgroud)