字符串问题。是否出现iPhone Apple等词;我考虑时想到既然是否有这些词,可以写map标记一下;然后又最长的是iPhone,6个单词,所以第一个for遍历所有单词
然后在一个for(1~6),用string+c[];然后判断是否该单词被标记,如果被标记过,那就是需要的词,随后第一个for加上单词长度;
#include<stdio.h> #include<string.h> #include<string> #include<algorithm> #include<map> using namespace std; int main() { int i,j; string s1,s2; char ss[1000]; while(gets(ss)!=NULL) { map<string,int>mp; s1="Apple"; mp[s1]=1; s1="iPhone"; mp[s1]=1; s1="iPod";mp[s1]=1; s1="iPad";mp[s1]=1; s1="Sony";mp[s1]=2; int len=strlen(ss); int flag; for(i=0;i<len;i++) { s1=""; flag=0; if(ss[i]==' ')continue; for(j=0;j<6;j++) { s1+=ss[i+j]; if(mp[s1]==1) { flag=1; printf("MAI MAI MAI!\n"); break; } else if(mp[s1]==2) { flag=1; printf("SONY DAFA IS GOOD!\n"); break; } } if(flag) { i=i+j; } } } }