UVA129

格式控制,没看到,开始wrong了

#include<cstdio>
#include<cstring>
using namespace std;
int n,L;
int cnt=0;
int S[90];

int dfs(int cur){
    if(cnt++ == n){

        int haha=0;
        for(int i=0;i<cur;i++) { if(i%4==0&&i!=0){ haha++; if(haha!=16)printf(" "); }if(haha==16) { haha++; printf("\n");}  printf("%c",S[i]+'A');  } printf("\n%d\n",cur);

        return 0;
    }
    else for(int i=0;i<L;i++)

        {
        S[cur]=i;
        int ok=1;
        for(int j=1;j*2<=cur+1;j++){
            int mark=1;
            for(int k=0;k<j;k++)
            if(S[cur-k]!=S[cur-k-j]) { mark=0; break; }
            if(mark) { ok=0; break; }
        }
        if(ok) if( !dfs(cur+1) ) return 0;
    }
//    printf("dsa\n");
    return 1;
}
int main(){
    while(~scanf("%d%d",&n,&L)&&n&&L)
    {

        cnt=0;
        dfs(0);
    }
    return 0;
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-10-11 12:14:23

UVA129的相关文章

UVA129 Krypton Factor

问题链接:UVA129 Krypton Factor. 问题简述:题目是氪因子.输入正整数n和L,输出由前L个字符组成的.字典顺序第n小的不含相邻重复字串的字符串.不含相邻重复字串的字符串是指,一个字符串中,任意两个相邻的字串都不相等.输出结果时,对于找到的字符串,每4个字符间加入一个空格,每行输出80个字符. 问题分析:回溯法实现.从第1个字符开始试探,每个字符从"A"开始可以是L个字符之一,直到遇见第n个满足条件的字符串.试探过程中,当前的串是不包含相邻相同子串的,所以只需要考虑加

uva129 - Krypton Factor 7.4.3 困难的串

  7.4.3困难的串 学习点:dfs加入返回值,递归搜索过程中如果有一个成功,就直接退出 //7.4.3 困难的串 #include<cstdio> #include<cstring> #include<iostream> #include<string> #include<algorithm> using namespace std; int n,L; int cnt; char v[81]; bool judge(int cur) { fo

UVa129 Krypton Factor (回溯法)

链接:http://acm.hust.edu.cn/vjudge/problem/19665分析:cnt用于统计困难串个数,以串的各个位置为状态DFS,由于要字典序第k小,所以枚举cur位置上的字符时要从小到大,每次DFS考虑当前串的后缀是否有困难串,找到一个困难串则cnt++然后继续递归枚举.回溯,如果找到第k个后打印输出最后一波return. 1 #include <iostream> 2 #include <algorithm> 3 using namespace std;

例题7-5 困难的串 UVa129

1.题目描述:点击打开链接 2.解题思路:本题利用回溯法解决.根据题意描述,易知在枚举第cur位时,只用检查它添加后该串是否合法,而不必去检查cur之间的串是否合法,因为这一步检查在枚举cur之前早已经做过了.另外,本题的输出比较坑,需要小心. 3.代码: #define _CRT_SECURE_NO_WARNINGS #include<iostream> #include<algorithm> #include<string> #include<sstream&

追溯法应用举例2-困难的串

题目选自UVA-129:https://vjudge.net/problem/UVA-129 在刘汝佳的紫书中,曾经强调利用八皇后中的思想,借助字符串的后缀来生成数据.不需要刻意验证当下递归中所添加的字母是否同以后添加的字母满足题目关系.这一点与八皇后代码中按照每行或每列逐一递归的思想是相吻合的.在我的代码中,对于每一次添加的字符,都需要与前方已经添加好的相邻的字符组合并对比,以此来检查它是否满足了简单的串的定义.借助一维数组,如果此时需要填充的位置下标是cur,而填充的字母与前面相邻的字母组成