参考代码:
#include <cstdio> #include <cstdlib> using namespace std; const char M[] = " abcdefghijklmnopqrstuvwxyz"; int s, t, w, cnt; char p[30]; bool vis[30]; void dfs(int x) { if (x == w + s) { if (cnt) puts(p + s); if (++cnt == 6) exit(0); return ; } for (int i = s; i <= t; ++i) { if (cnt == 0) i = p[x] - 'a' + 1; if (!vis[i] && M[i] > p[x-1] && i <= t - w + 1 + x - s) { vis[i] = true; p[x] = M[i]; dfs(x + 1); vis[i] = false; } } } int main() { scanf("%d%d%d", &s, &t, &w); scanf("%s", p + s); dfs(s); return 0; }
0.0分
1 人评分
【亲和数】 (C语言代码)浏览:536 |
ASCII帮了大忙浏览:748 |
蛇行矩阵 (C语言代码)浏览:742 |
C语言训练-大、小写问题 (C语言代码)浏览:611 |
【简单计算】 (C语言代码)浏览:622 |
C语言程序设计教程(第三版)课后习题10.3 (C语言代码)浏览:526 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:520 |
C语言程序设计教程(第三版)课后习题5.6 (C语言代码)浏览:504 |
简单的a+b (C语言代码)浏览:572 |
Tom数 (C语言代码)浏览:552 |