【算法 | 实验18】在字符矩阵中查找给定字符串的所有匹配项
创始人
2024-04-09 08:24:56
0

文章目录

  • 题目描述
  • 思路分析
  • bug记录:"error: '>>' should be '> >' within a nested template argument list"
  • 代码


题目描述

题目
在字符矩阵中查找给定字符串的所有匹配项
给定一个M×N字符矩阵,以及一个字符串S,找到在矩阵中所有可能的连续字符组成的S的次数。所谓的连续字符,是指一个字符可以和位于其上下左右,左上左下,右上右下8个方向的字符组成字符串。用回溯法求解。

输入描述
输入整数t表示测试用例个数
每个测试用例,输入整数M,N,表示矩阵的行数和列数。
接下来输入M行,每行输入N列个字符
第M+1行输入一个需要在矩阵中查找的字符串S
输出描述
输出t行,每行表示第t个测试用例中矩阵中字符串出现的次数

样例输入
1
5 5
D E M X B
A O E P E
D D C O D
E B E D S
C P Y E N
CODE
样例输出
8
样例解析,有一个测试样例,给定一个5行5列字符矩阵,要查找的字符串是CODE
输出为8表示矩阵中总共包含8个"CODE",如下所示,括号内为字符对应的行和列。
‘C’(2, 2) ‘O’(1, 1) ‘D’(0, 0) ‘E’(0, 1)
‘C’(2, 2) ‘O’(1, 1) ‘D’(2, 0) ‘E’(3, 0)
‘C’(2, 2) ‘O’(1, 1) ‘D’(2, 1) ‘E’(1, 2)
‘C’(2, 2) ‘O’(1, 1) ‘D’(2, 1) ‘E’(3, 0)
‘C’(2, 2) ‘O’(1, 1) ‘D’(2, 1) ‘E’(3, 2)
‘C’(2, 2) ‘O’(2, 3) ‘D’(2, 4) ‘E’(1, 4)
‘C’(2, 2) ‘O’(2, 3) ‘D’(3, 3) ‘E’(3, 2)
‘C’(2, 2) ‘O’(2, 3) ‘D’(3, 3) ‘E’(4, 3)


思路分析

和经典的回溯法走迷宫很像,比较不同的是:
1、有 8 个行走方向
2、需要统计能匹配目标字符串的路径的数量

关于 8 个行走方向,我差点就要上 8 个if了,好在及时想到了可以使用循环。

统计路径数:设从某个位置出发,能和目标字符串 S 的剩余部分匹配的路径数为 fff;从该位置周围的 8 个位置出发,能和目标字符串 S 的剩余部分匹配的路径数分别为 x1,x2,x3,x4,x5,x6,x7,x8x_1,x_2,x_3,x_4,x_5,x_6,x_7,x_8x1​,x2​,x3​,x4​,x5​,x6​,x7​,x8​,则:
f=x1+x2+x3+x4+x5+x6+x7+x8f = x_1+x_2+x_3+x_4+x_5+x_6+x_7+x_8f=x1​+x2​+x3​+x4​+x5​+x6​+x7​+x8​
例如在下图中,以中间的CCC为当前位置,则x1=5,x4=3x_1=5,x_4=3x1​=5,x4​=3,其余 x 为 0,f=5+3=8f=5+3=8f=5+3=8。
在这里插入图片描述


bug记录:“error: ‘>>’ should be ‘> >’ within a nested template argument list”

中文翻译:“错误:”>>“在嵌套模板参数列表中应为”> >”

// 错误代码
vector>
// 修改方案:在两个尖括号中加个空格
vector >

原因:在使用C++11之前标准的编译器将">>“视为移位符号,导致编译错误
参考:https://blog.csdn.net/yiti8689/article/details/108134804


代码

OJ成功通过了

#include
#include
#include
#include
using namespace std;//判断i, j是否在矩阵内 
bool inside(int i, int j, int m, int n){if(0 <= i && i < m && 0 <= j && j < n){return true;}return false;
}// 回溯实现
// 参数,i,j为当前位置;len为已成功匹配的字符个数;s为目标字符串; 
int hui_su(vector > a, int i, int j, int m, int n, int len, string s){if(a[i][j] != s[len]){return 0;}else {len++;if(s.length() == len){return 1;}}//向8个方向搜索 int count = 0;for(int x = -1; x <= 1; x++){for(int y = -1; y <= 1; y++){if(x == 0 && y == 0){continue;}if(inside(i+x, j+y, m, n)){count += hui_su(a, i+x, j+y, m, n, len, s);}}}return count;
}int main(){int t;  //测试用例个数cin >> t; // 输入for(int k = 0; k < t; k++){int m, n;  //矩阵的大小string s;  //目标字符串 cin >> m >> n;vector > a(m, vector(n));  //矩阵for(int i = 0; i < m; i++){for(int j = 0; j < n; j++){cin >> a[i][j];}} cin >> s;int count = 0;for(int i = 0; i < m; i++){for(int j = 0; j < n; j++){count += hui_su(a, i, j, m, n, 0, s);}}cout << count;} return 0;
}

相关内容

热门资讯

银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...