服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - c语言单词搜索的实现

c语言单词搜索的实现

2022-11-10 14:49Mr Gao C/C++

本文主要介绍了c语言单词搜索的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

单词搜索

给定一个 m x n 二维字符网格 board 和一个字符串单词 word 。如果 word 存在于网格中,返回 true ;否则,返回 false 。

单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中“相邻”单元格是那些水平相邻或垂直相邻的单元格。同一个单元格内的字母不允许被重复使用。

c语言单词搜索的实现

代码解题如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
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;
}

到此这篇关于c语言单词搜索的实现的文章就介绍到这了,更多相关c语言单词搜索内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/weixin_43327597/article/details/124221414

延伸 · 阅读

精彩推荐
  • C/C++C语言 栈的表示和实现详细介绍

    C语言 栈的表示和实现详细介绍

    这篇文章主要介绍了C语言 栈的表示和实现详细介绍的相关资料,需要的朋友可以参考下...

    C语言教程网6352021-04-21
  • C/C++c++如何实现Base64算法

    c++如何实现Base64算法

    这篇文章主要介绍了c++如何实现Base64算法,文中讲解非常细致,帮助大家更好的理解和学习c++,感兴趣的朋友可以了解下...

    阿凡卢10292021-09-22
  • C/C++C++抛出和接收异常的顺序

    C++抛出和接收异常的顺序

    这篇文章主要介绍了C++抛出和接收异常的顺序,帮助大家更好的理解和学习C++,感兴趣的朋友可以了解下...

    Dabelv6532021-09-22
  • C/C++C++中实现OpenCV图像分割与分水岭算法

    C++中实现OpenCV图像分割与分水岭算法

    分水岭算法是一种常用的图像区域分割法,本文主要介绍了OpenCV图像分割与分水岭算法,使用C++实现,具有一定的参考价值,感兴趣的可以了解一下...

    进击的Explorer12732021-11-14
  • C/C++C语言学生成绩管理系统课程设计

    C语言学生成绩管理系统课程设计

    这篇文章主要为大家详细介绍了C语言学生成绩管理系统课程设计,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    ZXLS-ZMR3982021-06-15
  • C/C++C语言使用Bresenham算法生成直线(easyx图形库)

    C语言使用Bresenham算法生成直线(easyx图形库)

    这篇文章主要为大家详细介绍了C语言使用Bresenham算法生成直线,基于easyx图形库,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们...

    MMagicLoren11612021-08-29
  • C/C++Opencv处理图像之轮廓提取

    Opencv处理图像之轮廓提取

    这篇文章主要为大家详细介绍了Opencv处理图像之轮廓提取,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    代码敌敌畏12192021-07-17
  • C/C++C++ 汉诺塔问题知识点总结

    C++ 汉诺塔问题知识点总结

    在本篇文章里小编给大家整理的是关于C++ 汉诺塔问题知识点内容,有需要的朋友们可以参考下。...

    000紫外线0008502021-08-17