广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >c语言单词搜索的实现
  • 187
分享到

c语言单词搜索的实现

2024-04-02 19:04:59 187人浏览 安东尼
摘要

单词搜索 给定一个 m x n 二维字符网格 board 和一个字符串单词 Word 。如果 word 存在于网格中,返回 true ;否则,返回 false 。 单词必须按照字母顺

单词搜索

给定一个 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语言单词搜索内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: c语言单词搜索的实现

本文链接: https://www.lsjlt.com/news/146263.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • c语言单词搜索的实现
    单词搜索 给定一个 m x n 二维字符网格 board 和一个字符串单词 word 。如果 word 存在于网格中,返回 true ;否则,返回 false 。 单词必须按照字母顺...
    99+
    2022-11-13
  • c语言怎么实现单词搜索
    本文小编为大家详细介绍“c语言怎么实现单词搜索”,内容详细,步骤清晰,细节处理妥当,希望这篇“c语言怎么实现单词搜索”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。单词搜索给定一个 m x n 二维字符网格 boa...
    99+
    2023-06-30
  • C++实现LeetCode(79.词语搜索)
    [LeetCode] 79. Word Search 词语搜索 Given a 2D board and a word, find if the word exists in the...
    99+
    2022-11-12
  • C语言中find_package()的搜索路径的实现
    目录find_package()Module模式Config模式find_package(OpenCV REQUIRED) 如何设置查找路径/指定只用版本find_package()...
    99+
    2022-11-12
  • C语言实例实现二叉搜索树详解
    目录有些算法题里有了这个概念,因为不知道这是什么蒙圈了很久。 先序遍历: root——>left——>right 中序遍历...
    99+
    2022-11-13
  • C语言实现二叉搜索树的完整总结
    目录1、 二叉树的构建2、二叉树的遍历前序遍历中序遍历后序遍历层序遍历4、二叉树的高度5、二叉树的删除6、由几种遍历序列还原二叉树 前序序列、中序序列还原二叉树:中序序列、...
    99+
    2022-11-12
  • C语言如何实现翻转字符串中的单词
    目录C语言翻转字符串中的单词另外开辟一个空间,来存放翻转的字符串直接在原数组上进行操作C语言字符串各单词的反转思路代码实现代码编译调试输出C语言翻转字符串中的单词 另外开辟一个空间,...
    99+
    2022-11-13
  • C语言实现统计一行字符串的单词个数
    目录问题简述解题思路程序代码测试结果问题简述 输入一行字符,统计其中有多少个单词,单词之间用空格分开 输入样例: I want to be a postgraduate. 输出样例:...
    99+
    2022-11-13
  • C语言中find_package()的搜索路径的实现是怎样的
    这篇文章给大家介绍C语言中find_package()的搜索路径的实现是怎样的,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。find_package()内部用find_path()和find_library()实现的找...
    99+
    2023-06-22
  • c#.net+SQL2005如何实现简单搜索
    今天就跟大家聊聊有关c#.net+SQL2005如何实现简单搜索,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。搜索函数 USE [DATA...
    99+
    2022-10-19
  • MySQL实现分词搜索(FULLTEXT)的方法
    目录FULLTEXT全文搜索的简单使用建表添加FULLTEXT索引尝试搜索结束FULLTEXT 以前使用查找时都是以 %关键字% 进行模糊查询结果的,这种查询方式有一些缺点,比如不能查询多个列必须手动添加条件以实现,效率...
    99+
    2022-10-17
  • C语言通过三步翻转法实现单词倒置详解
    目录一、解题思路二、完整代码与注释三、代码剖析1.实现字符串整体的翻转2.一个单词的翻转3.字符串中的每一个单词的翻转一、解题思路 如何将一句话的单词倒置,而标点不倒置? 例如:I ...
    99+
    2022-11-13
  • C语言实现电子英汉词典系统
    本文实例为大家分享了C语言实现电子英汉词典系统的具体代码,供大家参考,具体内容如下 一、设计功能(文章仅供参考) a. 词条录入:即添加单词记录。 b. 信息显示:将所有的...
    99+
    2022-11-13
  • PHP商城中的关键词搜索功能实现
    在现如今的电商时代,搜索功能已成为了电商网站上不可或缺的一部分,能够大大提高用户的购物体验。在PHP商城中,关键词搜索功能更是实现了这个功能的集大成者。本文将从关键词搜索的原理开始,深入探讨PHP商城中的关键词搜索功能实现。一、关键词搜索原...
    99+
    2023-05-22
    PHP 商城 关键词搜索 功能实现
  • C语言实现简单计算器
    本文实例为大家分享了C语言实现简单计算器的具体代码,供大家参考,具体内容如下 实现效果如图: 实现代码如下: #include<stdio.h> #include...
    99+
    2022-11-12
  • C语言实现简单的扫雷功能
    这是我跟着学习视频完成的第一个小游戏,运用到的知识不多都是数组相关的知识,重要的是思路,在设计的时候要先绘制出大概的框图,要知道游戏的根本,这样会让你写程序的时候更加方便。 下面看代...
    99+
    2022-11-12
  • C语言实现简单的抽奖系统
    本文实例为大家分享了C语言实现简单的抽奖系统的具体代码,供大家参考,具体内容如下 效果图 #include<stdio.h> #include<string.h...
    99+
    2022-11-13
  • 用C语言实现简单的三子棋
    三子棋代码的实现需要一个简单的思路做指引,所以我们先来做一下思路的整理,代码的实现主要分为以下几个步骤: 1.初始化数组2.显示数组3.电脑走4.玩家走5.判断输赢 所以,先写出源文...
    99+
    2022-11-13
  • C语言扫雷游戏的简单实现
    今天来用c语言做一个扫雷功能的简单实现,首先创建一个test.c来用于在写代码的途中测试扫雷代码,game.h来存放实现扫雷函数需要用到的头文件,game.c来存放最终的成品。 首先...
    99+
    2022-11-12
  • C语言计算字符串最后一个单词的长度
    描述: 计算字符串最后一个单词的长度,单词以空格隔开,字符串长度小于5000。(注:字符串末尾不以空格为结尾) 输入描述: 输入一行,代表要计算的字符串,非空,长度小于5000。 输...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作