重点有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<stdio.h>
#include<string.h>
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;
}