参考代码:
#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 人评分
点我有惊喜!你懂得!浏览:1462 |
C语言训练-排序问题<2> (C++代码)(sort函数)浏览:1719 |
C语言程序设计教程(第三版)课后习题6.1 (C语言代码)浏览:545 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:633 |
2003年秋浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:633 |
三角形 (C++代码)递推浏览:825 |
C语言程序设计教程(第三版)课后习题9.8 (C语言代码)浏览:702 |
Minesweeper (C语言描述,蓝桥杯)浏览:1176 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:645 |
1013题解浏览:596 |