L1-070 吃火锅 本题要求你实现一个程序,自动检查你朋友给你发来的信息里有没有 chi1 huo3 guo1。

 重点有2个:

1.怎么实现每段输入。两种解决办法,一种如下代码,二维数组储存每一段,第二种为利用while,每次char s[80]一个字符串再当场处理,处理以后再读取下一段句子重新定义一个char s[80]。

2.怎么查找吃火锅。第一反应想到的是c&&h&&i等等每个字母同时存在作为条件,但是过于繁琐。string.h中自带strstr查找函数,直接利用即可。使用strstr(s,target),target就是‘吃火锅’(如下),如果查找到了会返回首次出现target的地址,如果没有查到会返回NULL,所以直接if(!=NULL)来作为条件。

对了,有没有路过大佬教教   如果一句有多个“吃火锅”怎么办捏?

新人博主求赞~~

代码如下:

#include
#include
int main()
{
   char target[15]="chi1 huo3 guo1";
   char s[100][80];
   int i,j;
   int num1=0,num2=0;//分别是总信息数和有火锅的信息数
   int first;
   
	for(i=0;i<=100;i++)
{
   	gets(s[i]);
   	if(s[i][0]=='.'&&strlen(s[i])==1)//有.且单独一排则退出
   	{
   		num1=i;//总信息数,注意.这行不算信息数
   		break;
	}
	if(strstr(s[i],target)!=NULL)
	{
		num2++;
		if(num2==1)
		{
			first=i+1;//首次出现的行数0
		}
	}
}
   	if(num2!=0)
   	{
   		printf("%d\n",num1);
   		printf("%d %d",first,num2);	
	}
	else
	{
        printf("%d\n",num1);
		printf("-_-#");
	}
	
	return 0;
   	
}



你可能感兴趣的:(c语言,c++,算法)