検討:
a c p r c
x s o p c
v o v n i
w g f m n
q a t i t
次のいずれかの位置にある場合、アルファベットはタイル内の別のアルファベットに隣接してi_index
います。j_index
i_index
j_index
* * *
* x *
* * *
ここで、すべて*
はに隣接する場所を示しますx
。
タスクは、タイル内の特定の文字列を見つけることです。条件は、指定された文字列のすべての文字が隣接している必要があり、指定された文字列を構成するためにタイル内の1つの文字を複数回使用することはできないということです。
私は単純なバックトラックソリューションを考え出しました。そのソリューションはかなり高速ですが、最悪の場合の時間は本当に悪いです。
例:タイルの4x4がすべての's、つまり16 a 'で満たされ、検索する文字列がaaaaaaaaaaaaaaaab、つまり15a 'sと1つのbであるとします。1つは、タイルに表示されない文字を含む文字列を削除することです。しかし、それでも最悪のケースは、タイルにababababababababがあり、検索する文字列がabababababababbbbであると言うことで表示される可能性があります。
私の試みは次のようなものです:
#include <stdio.h>
#include <string.h>
#include <ctype.h>
#define MAX 5
int sp (char mat[MAX][MAX], char *pat, int c, int i, int j)
{
int r = 0;
char temp;
if (c == strlen (pat))
return 1;
if (((i<0) || (j<0)) || (i>=MAX) || (j>=MAX))
return 0;
if (mat[i][j] != pat[c])
return 0;
if (isupper (mat[i][j]))
return 0;
/* Save character and mark location to indicate
* DFS has visited this node, to stop other branches
* to enter here and cross over path
*/
temp = mat[i][j];
mat[i][j] = 0;
r |= sp (mat, pat, c+1, i-1, j-1);
r |= sp (mat, pat, c+1, i-1, j);
r |= sp (mat, pat, c+1, i-1, j+1);
r |= sp (mat, pat, c+1, i, j+1);
r |= sp (mat, pat, c+1, i+1, j+1);
r |= sp (mat, pat, c+1, i+1, j);
r |= sp (mat, pat, c+1, i+1, j-1);
r |= sp (mat, pat, c+1, i, j-1);
/* restore value */
mat[i][j] = temp;
/* mark if success */
if ((mat[i][j] == pat[c]) && (r == 1))
mat[i][j] = toupper (mat[i][j]);
return r;
}
/* Testing the `sp` module */
int main (void)
{
char mat[MAX][MAX] = {
{'a', 'c', 'p', 'r', 'c'},
{'x', 's', 'o', 'p', 'c'},
{'v', 'o', 'v', 'n', 'i'},
{'w', 'g', 'f', 'm', 'n'},
{'q', 'a', 't', 'i', 't'}
};
char pat[] = "microsoft";
int i, j;
for (i=0; i<5; i++)
{
for (j=0; j<5; j++)
printf ("%c ", mat[i][j]);
printf ("\n");
}
for (i=0; i<5; i++)
for (j=0; j<5; j++)
sp (mat, pat, 0, i, j);
printf ("\n\n\n");
for (i=0; i<5; i++)
{
for (j=0; j<5; j++)
{
if (isupper (mat[i][j]))
printf ("%c ", mat[i][j]);
else
printf (". ");
}
printf ("\n");
}
printf ("\n");
return 0;
}
印刷するもの:
a c p r c
x s o p c
v o v n i
w g f m n
q a t i t
. . . R .
. S O . C
. O . . I
. . F M .
. . T . .
この関数sp
は作業を行い、バックトラッキングを実行します。
もっと良い方法はありますか?または、最悪の場合の時間を短縮することは可能ですか?