日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

P1101 单词方阵(DFS)

發布時間:2023/12/13 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。