P1101 单词方阵(DFS)
生活随笔
收集整理的這篇文章主要介紹了
P1101 单词方阵(DFS)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
題目描述
給一n \times nn×n的字母方陣,內可能蘊含多個“yizhong”單詞。單詞在方陣中是沿著同一方向連續擺放的。擺放可沿著?88個方向的任一方向,同一單詞擺放時不再改變方向,單詞與單詞之間可以交叉,因此有可能共用字母。輸出時,將不是單詞的字母用*代替,以突出顯示單詞。例如:
輸入:8 輸出:qyizhong *yizhonggydthkjy gy******nwidghji n*i*****orbzsfgz o**z****hhgrhwth h***h***zzzzzozo z****o**iwdfrgng i*****n*yyyygggg y******g輸入輸出格式
輸入格式:
?
第一行輸入一個數nn。(7 \le n \le 1007≤n≤100)。
第二行開始輸入n \times nn×n的字母矩陣。
?
輸出格式:
?
突出顯示單詞的n \times nn×n矩陣。
?
輸入輸出樣例
輸入樣例#1:?復制
7 aaaaaaa aaaaaaa aaaaaaa aaaaaaa aaaaaaa aaaaaaa aaaaaaa輸出樣例#1:?復制
******* ******* ******* ******* ******* ******* *******輸入樣例#2:?復制
8 qyizhong gydthkjy nwidghji orbzsfgz hhgrhwth zzzzzozo iwdfrgng yyyygggg輸出樣例#2:?復制
*yizhong gy****** n*i***** o**z**** h***h*** z****o** i*****n* y******g題解:深度優先搜索搜即可,用結構體記錄路徑
代碼:
#include<cstdio> #include<cstring> #include<iostream> #include<algorithm>using namespace std;const int maxn=100+10; struct node {int x,y; }c[maxn];//記錄路徑 char fz[maxn][maxn],stand[]="yizhong";//fz保存單詞矩陣,stand保存保準的“yizhong”便于匹配 int vis[maxn][maxn];//保存路徑,是否該點為答案 int dir[][2]={{-1,-1},{-1,0},{-1,1},{0,-1},{0,1},{1,-1},{1,0},{1,1}};//八向的常量數組 void dfs(int x,int y,int k,int cur) {if(cur==7){for(int i=0;i<7;i++)vis[c[i].x][c[i].y]=1;}else{int dx=x+dir[k][0];//沿著正確的k方向搜索int dy=y+dir[k][1];if(cur==6||fz[dx][dy]==stand[cur+1]){c[cur].x=x;c[cur].y=y;dfs(dx,dy,k,cur+1);}} } int main() {int n;scanf("%d",&n);for(int i=0;i<n;i++)scanf("%s",fz[i]);//memset(vis,0,sizeof(vis));for(int i=0;i<n;i++)for(int j=0;j<n;j++)if(fz[i][j]=='y') for(int k=0;k<8;k++){int x=i+dir[k][0];int y=j+dir[k][1];if(fz[x][y]=='i')dfs(i,j,k,0);}for(int i=0;i<n;i++){//輸出結果for(int j=0;j<n;j++)if(vis[i][j]) printf("%c",fz[i][j]);else printf("*");printf("\n");}return 0; }?
轉載于:https://www.cnblogs.com/Staceyacm/p/10781972.html
總結
以上是生活随笔為你收集整理的P1101 单词方阵(DFS)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 平安信用卡优享金在哪里申请?申请流程很简
- 下一篇: 基于SOA的银行系统架构