参考代码:
#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语言代码)浏览:880 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:926 |
字符串输入输出函数 (C++代码)(都当成字符串吧hhhhhhhh)浏览:493 |
十->二进制转换 (C语言代码)浏览:1291 |
printf基础练习2 (C语言代码)浏览:740 |
A+B for Input-Output Practice (II) (C语言代码)浏览:989 |
The 3n + 1 problem (C语言代码)浏览:548 |
C语言程序设计教程(第三版)课后习题9.6 (C语言代码)浏览:371 |
C语言程序设计教程(第三版)课后习题4.9 (C语言代码)浏览:682 |
1014题解浏览:484 |