字符串匹配

问题描述:读入两个字符串a和b,判断a是否是b的子串。如果是,计算a在b中出现了几次。

例如:如果a="aba", b="ababab",则a在b中出现了两次。如果a="abc",b="ababab",则a不是b的子串。

代码如下:

#include <iostream>
#include <cstring>
using namespace std;
char a[100], b[100];
int la, lb, count;   				//定义两个字符串的长度和计数器 

void input_data()					//输入数据的过程 
{
	cin >> a;
	cin >> b;
}

void solve()						//解决问题的过程 
{
	bool match;						//表示从某一位置开始能否匹配 
	la = strlen(a);
	lb = strlen(b);
	count = 0;
	for (int i=0; i<=lb-la; i++)		// 循环变量i表示起始的位置 
	{
		match = true;
		for (int j=0; j<la; j++)
		{
			if (a[j]!= b[i+j])				//如果在某一位置无法匹配 
			{
				match = false;
				break;
			}
		}
		if (match)
			count++;
	}
}

void output_data()					//输出结果 
{
	if (count == 0)
		cout << "a不是b的子串"<< endl;
	else
		cout << "a在b中出现了"<< count << "次"<< endl; 
}

int main()
{
	input_data();
	solve();
	output_data();
	return 0;
}


posted @ 2015-06-09 20:38  Tovi  阅读(167)  评论(0编辑  收藏  举报