参考代码:
#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++代码)浏览:702 |
字符串输入输出函数 (Java代码)浏览:1434 |
简单的a+b (C++语言代码)浏览:852 |
上车人数 (C语言代码)浏览:767 |
A+B for Input-Output Practice (V) (C语言代码)浏览:617 |
简单的a+b (C语言代码)浏览:626 |
C语言程序设计教程(第三版)课后习题6.6 (C++代码)浏览:623 |
【明明的随机数】 (C语言代码)浏览:784 |
C语言程序设计教程(第三版)课后习题6.2 (C语言代码)浏览:684 |
C语言训练-自由落体问题 (C语言代码)浏览:609 |