字符串匹配

#include <stdio.h>
#include <assert.h>
#include <string.h>

#define MAX 1000
int getline(char line[], int max)
{
	int ch;
	int i = 0;
	while (max > 0 &&
		(ch = getchar()) != EOF && ch != '\n')
	{
		line[i] = ch;
		i++;
		max--;
	}
	if (ch == '\n')
		line[i++] = '\n';
	line[i] = '\0';
	if (i > 0)
		return 1;
	else
		return 0;
}
int match(char line[],char *mat)
{
	assert(line);
	assert(mat);
	int i=0, j=0, k=0;
	for (i = 0; i < strlen(line); i++)
	{
		for (k = i,j = 0; j < strlen(mat); j++,k++)
		{
			if (line[k] != *(mat + j))
				break;
		}
		if (*(mat+j) == '\0' && k>0)
			return 1;
	}
	return 0;
}
int main()
{
	char line[MAX];
	char *mat = "ould";
	while (getline(line,MAX))
	{
		if (match(line,mat))
			printf("%s", line);
	}
	return 0;
}


本代码主要实现字符串匹配问题。

输入一段文字(英文),然后输入想查找的部分,即可输出含有相同字符串的语句。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值