findStr
规则
在一个由大小写字母组成的矩阵中查找一个给定的字符串,这个字符串要求在矩阵中串成一个拐直角弯的相连序列,
形状像贪吃蛇一样,如果矩阵中存在这样的序列则查找成功。
目录结构

src/main.cpp
#include "../include/findstr.h"
int main(int argc, char* argv[])
{
if(argc !=3)
{
cout<<"argc should is 3, now it is "<<argc<<endl;
return 1;
}
findStr(argv[1],argv[2]);
return 0;
}
src/findstr.cpp
#include "../include/findstr.h"
using namespace std;
StrMatrix::StrMatrix(vector<string>&vectstr)
{
row = vectstr.size();
if(row>0)
{
col = vectstr[0].length();
}
else
return;
size = row*col;
pchar = new char[size];
pflag= new int[size];
int trow=0;
for (string str :vectstr)
{
for(int j=0; j<col ; j++)
pchar[j+trow*col] = str[j];
trow++;
}
}
void StrMatrix::clearFlag()
{
for (unsigned j = 0; j<size; j++)
{
pflag[j] = 1;
}
}
void StrMatrix::print()
{
for (unsigned j = 0; j<size; j++)
{
cout<<pchar[j]<<" ";
if((j+1)%col==0)
cout<<endl;
}
}
char StrMatrix::getchar(unsigned i, unsigned j)
{
if(i<row && j<col)
return pchar[i*col+j];
else
return ' ';
}
StrMatrix::~StrMatrix()
{
if (pchar != NULL)
{
delete[]pchar;
pchar= NULL;
}
if (pflag!= NULL)
{
delete[]pflag;
pflag= NULL;
}
}
void StrMatrix::setUsed(unsigned i,unsigned j)
{
if(i<row && j<col)
pflag[i*col+j]=0;
}
int StrMatrix::notUsed(unsigned i,unsigned j)
{
if(i<row && j<col)
return pflag[i*col+j] ;
else
return 0;
}
vector<string> split(const string &str, string ch = " ")
{
vector<string>ret;
int pos = 0;
int start = 0;
while ((pos = str.find(ch, start) )!= string::npos )
{
//cout << "pos:" << pos << endl;
if (pos>start)
ret.push_back(str.substr(start, pos-start));
start = pos+ch.size();
}
if (str.size()>start)
ret.push_back(str.substr(start));
return ret;
}
int checkPos(int i,int j, int*pos, char ch, int &validnum, StrMatrix &charMat)
{
if(charMat.notUsed(i,j) && charMat.getchar(i,j) == ch)
{
pos[validnum] = i;
pos[validnum+1] = j;
validnum+=2;
}
}
int recursion(int i,int j,StrMatrix &charMat, string curstr)
{
int ret=1;
int pos[6];
int validnum=0;
checkPos(i,j+1,pos,curstr[0],validnum,charMat);
checkPos(i,j-1,pos,curstr[0],validnum,charMat);
checkPos(i-1,j,pos,curstr[0],validnum,charMat);
checkPos(i+1,j,pos,curstr[0],validnum,charMat);
if(validnum>0 && curstr.length()==1)
{
//cout<<"has find!"<<endl<<endl;
return 0;
}
for(int cnt=0; cnt<validnum; cnt+=2)
{
//cout<<"ch: "<<charMat.getchar(pos[cnt],pos[cnt+1])<<endl;
charMat.setUsed(pos[cnt],pos[cnt+1]);
ret = recursion(pos[cnt],pos[cnt+1], charMat, curstr.substr(1));
if(ret == 0)
return 0;
}
return ret;
}
int findSingleStr(StrMatrix &charMat, string& curstr)
{
int ret=1;
for(int i=0; i<charMat.row; i++)
{
for(int j=0; j<charMat.col ; j++)
{
if(charMat.getchar(i,j) == curstr[0] )
{
if(curstr.length()==1)
return 0;
cout<<"head char:"<<charMat.getchar(i,j)<<endl;
charMat.clearFlag();
charMat.setUsed(i,j);
ret = recursion(i,j,charMat,curstr.substr(1));
if (ret == 0)
{
cout<<"find str:"<<curstr<<endl;
return 0;
}
}
}
}
return ret;
}
int findStr(string argvone,string argvtwo)
{
vector<string>onemat=split(argvone);
StrMatrix charMat(onemat);
charMat.print();
vector<string>strMatrix=split(argvtwo);
int ret=0;
for (string curstr :strMatrix)
{
//cout<<"curstr:"<<curstr<<endl;
ret |= findSingleStr(charMat, curstr );
}
return ret;
}
include/findstr.h
#include<iostream>
#include<string>
#include<vector>
using namespace std;
class StrMatrix{
public:
unsigned row, col, size;
char*pchar;
int*pflag;
StrMatrix(vector<string>&vectstr);
~StrMatrix();
void setUsed(unsigned i,unsigned j);
int notUsed(unsigned i,unsigned j);
void clearFlag();
void assignCharArr(vector<string>&);
char getchar(unsigned i, unsigned j);
void print();
};
vector<string> split(const string &str, string ch );
int findSingleStr(StrMatrix &charMat, string& curstr);
int findStr(string argvone,string argvtwo);
ft/TestCase.cpp
#include <gtest/gtest.h>
#include "../include/findstr.h"
TEST(FooTest, SingleCharCase)
{
EXPECT_EQ(findStr("qwer asdf zxcv", "s a d"),0);
}
TEST(FooTest, multiStrCase)
{
EXPECT_EQ(findStr("qwer asdf zxcv", "qwsxcv qwedsazxcv rfvcxzaswq"),0);
}
TEST(FooTest, UseTwiceiSameChar)
{
EXPECT_EQ(findStr("qwer asdf zxcv", "aa cvc qazxz"),1);
}
TEST(FooTest, NotSerieschar)
{
EXPECT_EQ(findStr("qwer asdf zxcv", "qsc asf zxdf qwdf"),1);
}
ft/makefile
cc = g++ -std=c++11
prom = ../output/ft
deps = ../include/findstr.h
obj = ../src/findstr.o TestCase.o
LIBS = -lgtest -lgtest_main -lpthread
$(prom): $(obj)
$(cc) $(obj) $(LIBS) -o $(prom)
%.o: %.c $(deps)
$(cc) -c $< -o $@
ftbuild.sh
cd ft
make
cd ../output
echo $(pwd)
./ft
mainbuild.sh
g++ -std=c++11 -g src/*.cpp -o output/findstr
findStr的更多相关文章
- [转]FINDSTR正则表达式小结
前言:最近写了一个bat用于快速编译swf至目标目录,想利用FINDSTR命令通过匹配目标目录名称,匹配数量大概600多个,发现匹配耗时比较久,大概花费10余秒,因此还是放弃字符匹配,乖乖拼出全称来定 ...
- findstr 命令
body { font-family: Bitstream Vera Sans Mono; font-size: 11pt; line-height: 1.5; } html, body { colo ...
- matlab中findstr,strfind,strcmp,strncmp区别与联系
在Matlab中,这几个函数区分如下: (以下默认S1和S2是字符串,同样也适用于cell细胞类型数据,也就是循环对cell中每个元素分别判断即可.) findstr(S1,S2):寻找是否有S1和S ...
- findstr()与strfind()的区别
matlab中这两个字符串查找的函数findstr(), strfind()表明上看起来用法相似,效果也相似. 1. findstr(s1,s2)--在较长的字符串中查找较短的字符串出现的次数,并返回 ...
- netstat -aon|findstr 8888 终止进程
netstat -aon|findstr 8888 # 根据端口号查找进程C:\Users\Administrator>netstat -ano | findstr TCP LISTENING ...
- 入门命令13-字符串查找增强:findstr
http://www.cnblogs.com/doupip/archive/2011/12/23/2299210.html 在文件中寻找字符串. FINDSTR [/B] [/E] [/L] [/R] ...
- 批处理 Mysql Findstr
@set Dump_IP=localhost @set User_Name=root @set Password=1234 @set curPath=%~dp0 mysql -h %Dump_IP% ...
- find和findstr
find与findstr 例“ 在文件中搜索字符串. 1.findstr . 2.txt 或 Findstr "." 2.txt 从文件2.txt中查找任意字符,不包括空字符或空行 ...
- 【CMD】findstr命令
findstr用来搜索匹配字符串的文件. FINDSTR [/B] [/E] [/L] [/R] [/S] [/I] [/X] [/V] [/N] [/M] [/O] [/P] [/F:file] [ ...
- 批处理find&findstr命令--众里寻他一次度
find 使用 Command: find [/v][/c][/n][/i] "string" [[drive:][path]filename] Parameter: /v 显示所 ...
随机推荐
- 网页出现400 Bad Request Request Header Or Cookie Too Large错误的解决方法
在开发项目过程中,突然遇到400 Bad Request Request Header Or Cookie Too Large的报错,我也是第一次出现这样的错误,感觉还是挺新奇的. 分析下出现错误的原 ...
- RobotFrameWork环境搭建(基于HTTP协议的接口自动化)
1. 前言 接着上一篇<RobotFramework框架系统课程介绍>,本篇主要介绍一下在基于RobotFramework框架开展接口自动化前,前期的环境如何搭建,正所谓”工欲善其事,必先 ...
- linux下fallocate快速创建大文件
以前创建文件我一般用dd来创建,例如创建一个512M的文件: dd命令可以轻易实现创建指定大小的文件,如 dd if=/dev/zero of=test bs=1M count=1000 会生成一个1 ...
- 导出表结构到Excel 生成代码用
导出表结构到Excel ,统一维护,生成代码用 SELECT C.TABLE_NAME,CC.COMMENTS,C.COLUMN_NAME,C.DATA_TYPE, CASE WHEN C.DATA_ ...
- DR、BDR、SBR、ASBR等名词的解释和原理
DR是指定路由器的意思是为了解决LSA在一个area里浪费很大的带宽而设计的 BDR是备份指定路由器,就是DR的一个备用.DR和BDR只在广播网和NBMA网络中有,而P2P和P2MP中是没有的. AB ...
- myeclipse中的项目 如何在项目视窗中显示setting,classpath等配置文件
导入了别人的项目,各种jar包都放好后,path也都build好了,项目也能正常启动,但是就是项目名有红叉,这是为什么呢? 网上有人说Java build path中的jar包missing了,这是一 ...
- php -v 与phpinfo显示版本不一样
问题描述: php -v显示版本7.0 phpinfo 显示版本 7.2 使用软件phpstudy 原因:环境变量中显示的是7.0,所以php -v显示的也是7.0 解决办法:修改环境变量,然后重启电 ...
- springboot-aop面向切面编程
需求: 项目中需要记录用户操作信息,例如用户登陆系统后做了那些操作,需要有具体的日志记录. 解决办法: 1.编写操作记录日志业务类,在使用的方法中调用(一般记录方式). 2.使用面向切面方式记录日志, ...
- Zend Optimizer,Zend Guard Loader 和 Zend Opcache 三者之间的区别
PHP的加速插件有三个:Zend Optimizer.Zend Guard Loader 和 Zend Opcache.但其实都是一个,针对不通的php版本.名字叫法不一样而已. Zend Optim ...
- 0710 mux协议的作用(ppp拨号时如何和gprs进行at指令交互)
ppp拨号使gprs上网的同时如何和gprs模块进行at指令的交互,这是一个问题. 在linux中,ppp拨号上网是内核中支持的,只需要在内核配置中选上. ppp拨号的方式使gprs进行上网与at指令 ...