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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

洛谷——P1101 单词方阵

發布時間:2024/2/28 编程问答 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 洛谷——P1101 单词方阵 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題目描述

給一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

?

作者:?hzg0226

#include <iostream> #include <memory.h> using namespace std;const int maxn = 100+10; struct node {int x, y; }c[maxn];int n; char map[maxn][maxn], str[] = "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, node c[], 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];int dy = y + dir[k][1];if(cur == 6 || map[dx][dy] == str[cur+1]) //能夠匹配,就記錄下路徑{c[cur].x = x, c[cur].y = y;dfs(dx,dy,c,k,cur+1); //繼續遞歸}} }int main() {scanf("%d", &n);for(int i = 0; i < n; i++){scanf("%s", &map[i]);}memset(vis,0,sizeof(vis));for(int i = 0; i < n; i++){for(int j = 0; j < n; j++){if(map[i][j] == 'y'){for(int k = 0; k < 8; k++){int x = i + dir[k][0];int y = j + dir[k][1];if(map[x][y] == 'i') //找到正確的方向,按著正確的那個方向進行遞歸!dfs(i,j,c,k,0);}}}}for(int i = 0; i < n; i++){for(int j = 0; j < n; j++){if(vis[i][j]) printf("%c", map[i][j]);else printf("*");}printf("\n");}return 0; }

這道題思來想去有思路,但是實現都很復雜。搜索一直是我的弱項,枯了。然后看了大牛的題解。

豁然開朗。

超強干貨來襲 云風專訪:近40年碼齡,通宵達旦的技術人生

總結

以上是生活随笔為你收集整理的洛谷——P1101 单词方阵的全部內容,希望文章能夠幫你解決所遇到的問題。

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