c语言单词搜索的实现

 更新时间:2022年04月17日 16:25:28   作者:Mr Gao  
本文主要介绍了c语言单词搜索的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

单词搜索

给定一个 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;
}

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

相关文章

  • C++实现LeetCode(169.求大多数)

    C++实现LeetCode(169.求大多数)

    这篇文章主要介绍了C++实现LeetCode(169.求大多数),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • C语言实现电子秒表

    C语言实现电子秒表

    这篇文章主要为大家详细介绍了C语言实现电子秒表,毫秒级秒表,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06
  • c++回调之利用函数指针示例

    c++回调之利用函数指针示例

    这篇文章主要介绍了c++利用函数指针示例,需要的朋友可以参考下
    2014-04-04
  • C语言链表实现图书管理系统

    C语言链表实现图书管理系统

    这篇文章主要为大家详细介绍了C语言链表实现图书管理系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • Pipes实现LeetCode(194.转置文件)

    Pipes实现LeetCode(194.转置文件)

    这篇文章主要介绍了Pipes实现LeetCode(194.转置文件),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • C/C++实现枚举网上邻居信息的示例详解

    C/C++实现枚举网上邻居信息的示例详解

    在Windows系统中,通过网络邻居可以方便地查看本地网络中的共享资源和计算机,本文将介绍一个简单的C++程序,使用Windows API枚举网络邻居信息,并获取对端名称、本机名称、主机名称以及主机IP等信息,文中通过代码示例给大家讲解非详细,需要的朋友可以参考下
    2023-12-12
  • C语言模拟实现C++的继承与多态示例

    C语言模拟实现C++的继承与多态示例

    本篇文章主要介绍了C语言模拟实现C++的继承与多态示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • C++实现航空订票程序

    C++实现航空订票程序

    这篇文章主要为大家详细介绍了C++实现航空订票程序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • C++ stack用法总结(示例详解)

    C++ stack用法总结(示例详解)

    std::stack 是 C++ 标准模板库(STL)中的容器适配器,它提供了栈(stack)的功能,基于其他序列容器实现,下面给大家介绍std::stack 的用法总结,感兴趣的朋友一起看看吧
    2024-01-01
  • C++虚函数和多态超详细分析

    C++虚函数和多态超详细分析

    这篇文章主要介绍了C++多态的特性派生与虚函数与模板,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2023-01-01

最新评论