题目背景
一封好的情书需要撰写人全身心的投入。CYY同学看上了可爱的c**想对她表白,但却不知道自己写的情书是否能感动她,现在他带着情书请你来帮助他。
题目描述
为了帮助lin_toto,我们定义一个量化情书好坏的标准感动值。判断感动值的方法如下:
1.在情书的一句话中若含有给定词汇列表中的特定单词,则感动值加1,但每一单词在同一句话中出现多次感动值不叠加,不同单词不受影响。保证输入的单词不重复。
2.每句话以英文句号定界。
3.全文不区分大小写。
输入输出格式
输入格式:
第一行包含一个数字n,表示导致感动值提升的词汇列表中单词的数量,随后n行是给定单词,每行一个。保证单词只包含英文字母。
最后一行为情书正文,保证只包含以下几种字符: 英文字母、数字、空格、英文逗号、英文句号。
输出格式:
一个数字g,表示情书带来的感动值。
输入输出样例
输入样例#1:
3
love
so
much
I love you so much.
输出样例#1:
3
code:
#define _CRT_SECURE_NO_WARNINGS//这句是允许使用不安全的函数
#include<stdio.h>
#include<string.h>
int main()
{
int i=0,ai=0,len,d=0,m=1;
char str1[100][100] , str2[100], str3[100] = { "\0" }, c, *token = NULL, num = 0;
printf("请输入满足感动的数字和单词:\n");
scanf_s("%d", &i);
for (int k = 0; k <= i; k++)//获取增加感动值的单词
{
gets(str1[k]);
}
fflush(stdin);//清空输入缓存
printf("请输入情书:");
while ((c=getchar()) != '.')//获取情书
{
str2[d++] = c;
}
str2[d] = '\0';//去掉句号,同时是结束标志
len=strlen(str2);
//printf("%s\n", str2);
token = strtok(str2, " ");//分割情书,以空格为界,但是只能分割一次,比如输入了 love you.
//上面这条命令执行之后str2=“you”
while (token != NULL) //续着上面的继续分割
{
for (int l = 0; l < len; l++)
{
if (strcmp(str1[l], token) == 0)//对比
{
ai++;
strcpy(str1[l], "\0");
}
}
//printf("%s\n", token);
token = strtok(NULL, " ");
}
printf("ai=%d\n", ai);
return 0;
}
问题解决