poj 百练2744( 基础题)

枚举子类字符串

好吧,GCC/G++

strrev不是ANSI C/C++库函数,所以不支持

好吧。。额

Compiler Error

其实可以换成C++ STL来写

枚举枚举

STL 标准reverse算法

#include <fstream>
#include <string.h>
#include <cstdio>
using namespace std;

#define _cdebbug



//全局数据
char str[100][101];
int i,j,n;
int t;
int count = 0;
char ministr[101];
int ministrlen;

void getnext(char str[],int len,int next[])
{
	int i = 0;       //主串不回溯
    int k = -1;      //副串指针小标 一个i,一个k
	next[0] = -1;    //第一个模式next值为-1
	while(i < len)
	{
		while(k >= 0 && str[i] != str[k])
			k = next[k];
		i++;
		k++;
		if (i == len)
			break;
		if (str[i] == str[k])
			next[i] = next[k];
		else
			next[i] = k;
	}


}
int kmp(char target[],char patter[],int next[],int tlen,int plen)
{
	int i = 0;
	int j = 0;
	if (tlen < plen)
		return -1;
	while(i < plen && j < tlen)
	{
		if (i == -1 || target[j] == patter[i])
		{
			++i;
			++j;
		}
		else
			i = next[i];
	}
	if (i >= plen)
		return(j - plen + 1);
	else
		return - 1;

}


int substrcnt(char * source)
{
	int subStrLen = strlen(source);
	int sourceStrLen = strlen(source);
	bool found;
	char subStr[101],revSubStr[101];
	int i,j;
	while(subStrLen > 0)
	{
		for (i = 0; i <= sourceStrLen - subStrLen; ++i)
		{
			strncpy(subStr, source + i, subStrLen);
			strncpy(revSubStr, source + i, subStrLen);
			subStr[subStrLen] = revSubStr[subStrLen] = '\0';
			strrev(revSubStr);
			found = true;
			for (j = 0; j < n; ++j)
				if (strstr(str[j], subStr) == NULL && strstr(str[j], revSubStr) == NULL)
				{
					found = false;
					break;
				}
			if (found)
				return subStrLen;
		}
		subStrLen--;
	}
	return 0;
}



int main()
{
	//重定向
#ifdef _cdebbug
	freopen("F:\\input.txt","r",stdin );
#endif
	

	scanf("%d",&t);
	while(t--)
	{
		scanf("%d",&n);
		ministrlen = 100;
		for (i = 0; i < n; ++i)
		{
			scanf("%s",str[i]);
			if (strlen(str[i]) < ministrlen)
			{
				strcpy(ministr,str[i]);
				ministrlen = strlen(ministr);
			}
		}
		count = substrcnt(ministr);
		printf("%d\n",count);
	}
	
	/*
	char strtest[] = "abcdaabcab";
	int len = 10;
	int next[10];
	getnext(strtest,len,next);
	int re = kmp(strtest,"aabcak",next,10,6);
	*/

	//解除重定向关闭文件
	
#ifdef _cdebbug
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           	fclose(stdin); 
#endif
	return 0 ;
}


 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值