数据结构与算法解析习题1.2:编写一个程序求解字谜游戏问题。

此题最简单直接解法就是暴力遍历,从矩阵中每个字符开始遍历,2-5的字母长度,8个方向,每一种组合都匹配一遍dict中的每个字符串,如果匹配成功,就返回。。


#include <stdlib.h>
#include <stdio.h>
#include <string.h>

static char puzzle[4][4] = {
    {'t','h','i','s'},
    {'w','a','t','s'},
    {'o','a','h','g'},
    {'f','g','g','t'}
};

static char *dict[4] = {"this","two","fat","that"};

int wordExist(int x, int y, int dir, int strlen, char *word, int (*position)[2]);

int main() {
    char word[5];
    int position[4][2];
    int x, y, dir, strlen;

    for(x = 0; x < 4; x++) {
        for(y = 0; y < 4; y++) {
            for(dir = 0; dir < 8; dir++) {
                for(strlen = 2; strlen < 5; strlen++) {
                    // 坐标 x y
                    // 方向 dir
                    // 单词长度从2开始
                    if(wordExist(x, y, dir, strlen, word, position) == 1) {
                        printf("word: %s\n",word);

                        printf("posotin :");

                        for (int i = 0; i < 4; ++i) {
                            printf("%d,%d  ", position[i][0], position[i][1]);
                        }

                        printf("\n");

                        break;
                    }
                }
            }
        }
    }

    return 0;
}


int wordExist(int x, int y, int dir, int strlen, char *word, int position[][2])
{
    // 先清空位置信息,-1为无效位置
    for (int i = 0; i < 4; ++i) {
        for (int j = 0; j < 2; ++j) {
            position[i][j] = -1;
        }
    }

    char sword[5];
    int i = 0, j;
    while(i < strlen) {
        position[i][0] = x;
        position[i][1] = y;
        sword[i++] = puzzle[x][y];
        sword[i] = '\0';
        for(j = 0; j < 4; j++) {
            // 如果字符串相同
            if(strcmp(sword,dict[j]) == 0) {
                strcpy(word,dict[j]);
                return 1;
            }
        }

        switch (dir) {
            case 0:        //从左到右
                y++;
                break;
            case 1:        //从右到左
                y--;
                break;
            case 2:        //从上到下
                x++;
                break;
            case 3:        //从下到上
                x--;
                break;
            case 4:        //从左上到右下
                x++;
                y++;
                break;
            case 5:        //从右下到左上
                x--;
                y--;
                break;
            case 6:        //从左下到右上
                x--;
                y++;
                break;
            case 7:        //从右上到左下
                x++;
                y--;
                break;
            default:
                puts("Direction error.");
                return 0;
        }

        if(x < 0 || y < 0)
            return 0;
    }
    return 0;
}