網站首頁 編程語言 正文
單詞搜索
給定一個 m x n 二維字符網格 board 和一個字符串單詞 word 。如果 word 存在于網格中,返回 true ;否則,返回 false 。
單詞必須按照字母順序,通過相鄰的單元格內的字母構成,其中“相鄰”單元格是那些水平相鄰或垂直相鄰的單元格。同一個單元格內的字母不允許被重復使用。
代碼解題如下:
int pi,pj;
//static int r[100][100];
void f(char** board,int n ,int m,int x,int y,char * word,int p,int **r, int *rz){
int a[4][2]={{0,-1},{-1,0},{0,1},{1,0}};
// printf(" %d ",r[x][y]);
int nx,ny;
int i,j;
int cc=0;
int l=0;
int zx,zy;
//printf("%d ",r);
// r[x][y]=1;
//printf(" --p %d %d ",p,rz);
if(m>=3)r[0][3]=0;
//printf("%d %c ",r[0][3],word[p]);
for(i=0;i<4;i++){
nx=a[i][0]+x;
ny=a[i][1]+y;
// if(nx==2)printf(" --nx ny %d %d %c",nx,ny,word[p]);
if(nx>=0&&nx<=n&&ny>=0&&ny<=m){
if(r[nx][ny]>=1 &&r[nx][ny]<=p*2&&board[nx][ny]==word[p-1]){
r[nx][ny]++;
// printf("%d %d ",nx,ny);
f(board,n,m,nx,ny,word,p,r,rz);
// f(board,n,m,pi,pj,word,p,r,rz);
// f(board,n,m,0,0,word,p,r,rz);
}
if(r[nx][ny]==0){
// printf("ddf sa ");
if(board[nx][ny]==word[p]){
for(j=0;j<4&&j!=i;j++){
zx=a[i][0]+x;
zy=a[i][1]+y;
if(board[zx][zy]==word[p]) {
// printf("&& %c %d %d ",word[p],zx,zy);
r[zx][zy]=0;
// if(zx==0&&zy==3)
// printf("r %d %d %d ",r[zx][zy],zx,zy);
}
}
// printf(" nx ny %d %d %c",nx,ny,word[p]);
// p++;
// cc++;
// printf("-- %c",word[p]);
r[nx][ny]=1;
printf("r %d %d %d %d ",r[nx][ny],nx,ny);
f(board,n,m,nx,ny,word,p+1,r,rz);
}
}
}
}
// printf(" --p %d %d ",p,rz);
// if(cc==0){r[x][y]=0;}
if(word[p]=='\0') {
// printf(" **p %d %d",p,rz);
*rz=1;}
//
// return true;
}
bool exist(char** board, int boardSize, int* boardColSize, char * word){
int i,j;
int n=boardSize-1;
int m=boardColSize[0]-1;
int p=1;
int x=0,y=0;
int row;
int z,w;
int rz=0;
// r[x][y]=1;
// printf("-- %d ",rz);
int **r = (int **)malloc(sizeof(int*) *boardSize );
for(row = 0 ; row < boardSize; row++)
{
r[row] = (int *)malloc(sizeof(int) * boardColSize[0]);
memset(r[row],0,sizeof(int) * boardColSize[0]);
}
// printf("%d %d ",n,m);
for(i=0;i<=n;i++){
for(j=0;j<=m;j++){
// printf("%c ",board[i][j]);
if(board[i][j]==word[0]){
for(z=0;z<=n;z++){
for(w=0;w<=m;w++){
r[z][w]=0;
// printf("%c ",board[i][j]);
}
}
r[i][j]=1;
pi=i;
pj=j;
f(board,n,m,i,j,word,p,r,&rz);
}
}
}
// printf(" zz %d ",rz);
if(rz==1)return true;
else return false;
}
原文鏈接:https://blog.csdn.net/weixin_43327597/article/details/124221414
相關推薦
- 2022-05-21 云原生技術持久化存儲PV與PVC_云其它
- 2023-05-08 Docker中的compose簡介_docker
- 2022-10-22 Kotlin匿名函數使用介紹_Android
- 2022-08-13 微信公眾號--根據用戶的opneId發送模版消息
- 2023-07-28 el-tabs 切換之前判斷是否滿足條件,不滿足則提示用戶,不能切換
- 2022-10-25 Go語言實戰學習之流程控制詳解_Golang
- 2023-03-20 Redis使用Bitmap的方法實現_Redis
- 2022-04-19 開發中為什么用translate來改變位置而不是定位?
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支