oj地址是韓國網站 鏈接比較慢 https://algospot.com/judge/problem/read/BOGGLE
大意以下ios
輸入輸出c++
輸入 1 URLPM XPRET GIAET XTNZY XOQRS 6 PRETTY GIRL REPEAT KARA PANDORA GIAZAPX 輸出 PRETTY YES GIRL YES REPEAT YES KARA NO PANDORA NO GIAZAPX YES
估摸着很簡單 就蹭蹭8個方向DFS 代碼寫完
測試用例過了
代碼以下數組
#include <iostream> #include <string> #include <vector> using namespace std; int n, m; int record = 0; const int dx[8] = { -1,-1,-1,1,1,1,0,0 }; const int dy[8] = { -1,0,1,-1,0,1,-1,1 }; bool isrange(int x, int y) { if (x < 0 || x >= 5 || y < 0 || y >= 5) return false; return true; } bool hasword(int x, int y, const string& word ,int idx,const vector<vector<char>>& table) { if (!isrange(x, y)) return false; if (table[x][y] != word[idx]) return false; if (idx == word.size()-1) return true; for (int i = 0; i < 8; i++) { int nextx = x + dx[i]; int nexty = y + dy[i]; if (hasword(nextx, nexty, word,idx+1, table)) return true; } return false; } int main() { int t = 0; cin >> t; while (t--) { vector<vector<char>> table(5, vector<char>(5, 0)); for (int i = 0; i < 5; i++) { for (int j = 0; j < 5; j++) { cin >> table[i][j]; } } int check = 0; cin >> check; vector<string> checkWord; while (check--) { string s; cin >> s; int find = 0; record = 0; for (int i = 0; i < 5; i++) { for (int j = 0; j < 5; j++) { if (hasword(i, j, s, 0,table)) { cout << s << " YES" << endl; find = 1; goto LABEL; } } } LABEL: if (0 == find) { cout << s << " NO" << endl; } } } return 0; }
可是竟然一個特殊用例過不了 代碼被判爲TLE緩存
輸入 1 AAAAA AAAAA AAAAA AACCC AACCB 1 AAAAAAAAAB
冥思苦想不得其門 只得針對該例子進行了特殊處理 翻轉字符串!
添加代碼很少 僅僅多了 reverse(s.begin(), s.end()); 一行ide
1 #include <iostream> 2 3 #include <iostream> 4 #include <string> 5 #include <vector> 6 #include <algorithm> 7 8 using namespace std; 9 10 int n, m; 11 12 const int dx[8] = { -1,-1,-1,1,1,1,0,0 }; 13 const int dy[8] = { -1,0,1,-1,0,1,-1,1 }; 14 15 vector<vector<int>> mem(5, vector<int>(5, 0)); 16 17 bool isrange(int x, int y) { 18 if (x < 0 || x >= 5 || y < 0 || y >= 5) 19 return false; 20 21 return true; 22 } 23 24 25 26 bool hasword(int x, int y, const string& word, int idx, const vector<vector<char>>& table) 27 { 28 if (!isrange(x, y)) { 29 return false; 30 } 31 32 if (table[x][y] != word[idx]) { 33 34 return false; 35 } 36 37 if (idx >= word.size() - 1) return true; 38 39 for (int i = 0; i < 8; i++) { 40 int nextx = x + dx[i]; 41 int nexty = y + dy[i]; 42 if (hasword(nextx, nexty, word, idx + 1, table)) 43 return true; 44 } 45 46 return false; 47 } 48 49 50 51 int main() 52 { 53 int t = 0; 54 cin >> t; 55 while (t--) { 56 vector<vector<char>> table(5, vector<char>(5, 0)); 57 for (int i = 0; i < 5; i++) { 58 for (int j = 0; j < 5; j++) { 59 cin >> table[i][j]; 60 } 61 } 62 63 int check = 0; 64 cin >> check; 65 vector<string> checkWord; 66 67 while (check--) { 68 string s; 69 cin >> s; 70 string copys = s; 71 reverse(s.begin(), s.end()); 72 int find = 0; 73 for (int i = 0; i < 5; i++) { 74 for (int j = 0; j < 5; j++) { 75 mem[i][j] = 1; 76 } 77 } 78 for (int i = 0; i < 5; i++) { 79 for (int j = 0; j < 5; j++) { 80 if (hasword(i, j, s, 0, table)) { 81 cout << copys << " YES" << endl; 82 find = 1; 83 goto LABEL; 84 } 85 } 86 } 87 88 LABEL: 89 if (0 == find) { 90 cout << copys << " NO" << endl; 91 } 92 } 93 } 94 95 96 return 0; 97 }
可是實際上 當測試字符串爲AAAAAAAAABAAAAAAAA 也同樣會TLE
因此 實際上咱們須要使用數組緩存從當前格子出發不能解決的字符串記錄 避免屢次重複嘗試失敗的路徑
代碼添加了一個變量數組
int d[x][y][l]; 記錄x y格子出發的嘗試匹配長度爲l的字符串 可否成功,若是失敗則置0。
下次DFS 發現該標記爲 0 則直接返回 不進行嘗試測試
1 #include <bits/stdc++.h> 2 using namespace std; 3 int T,n,c[15][15],cw[15],len[15]; 4 char a[15][15],w[15][15]; 5 int nx[10] = {1,0,-1,-1,-1,0,1,1},ny[10] = {1,1,1,0,-1,-1,-1,0}; 6 int dx,dy,is; 7 int d[15][15][15]; 8 9 int dfs(int x,int y,int now,int l) 10 { 11 if(d[x][y][l]) return 0; 12 if(l == len[now]) return 1; 13 d[x][y][l] = 1; 14 is = 0; 15 for(int i = 0;i < 8;i++) 16 { 17 dx = x+nx[i]; 18 dy = y+ny[i]; 19 if(a[dx][dy] == w[now][l]) 20 { 21 if(dfs(dx,dy,now,l+1)) 22 { 23 //c[x][y] = 0; 24 return 1; 25 } 26 } 27 } 28 //d[x][y][l] = 0; 29 return 0; 30 } 31 32 int main() 33 { 34 scanf("%d",&T); 35 while(T--) 36 { 37 memset(cw,0,sizeof(cw)); 38 for(int i = 1;i <= 5;i++) 39 { 40 for(int j = 1;j <= 5;j++) 41 { 42 scanf(" %c",&a[i][j]); 43 } 44 } 45 scanf("%d",&n); 46 for(int i = 1;i <= n;i++) 47 { 48 scanf("%s",w[i]); 49 len[i] = strlen(w[i]); 50 for(int j = 1;j <= 5;j++) 51 { 52 for(int k = 1;k <= 5;k++) 53 { 54 if(a[j][k] == w[i][0]) 55 { 56 if(dfs(j,k,i,1)) 57 { 58 cw[i] = 1; 59 break; 60 } 61 } 62 } 63 if(cw[i]) break; 64 } 65 memset(d,0,sizeof(d)); 66 } 67 for(int i = 1;i <= n;i++) 68 { 69 printf("%s %s\n",w[i],((cw[i] == 1) ? "YES" : "NO")); 70 } 71 } 72 }