1.解题思路
虽然输入方法不一样,但是都有一个共同点:m为单词的个数,后头的算法一样,先把重复的单词设为空,再数有多少个不是空格的元素。
2.参考代码:
2.1.用gets
#include<iostream> #include<cstring> using namespace std; int main(){ int i=0,j=0,m=0,count=0; char a[10001],b[100][100]; gets(a); for(i=0,m=0,j=0;i<strlen(a);i++){ if(a[i]!=' '){ b[m][j]=a[i]; j++; } else{ m++; j=0; } } for(i=0;i<=m;i++) for(j=i+1;j<=m;j++) if(strcmp(b[i],b[j])==0) strcpy(b[j],""); for(i=0;i<=m;i++) if(strcmp(b[i],"")==0) count++; cout<<m-count+1; return 0; }
2.2.不用gets
#include<iostream> #include<cstring> using namespace std; int main(){ int count=0,m=0,i,j; char a[100][100]; while(cin>>a[m]) m++; for(i=0;i<=m;i++) for(j=i+1;j<=m;j++) if(strcmp(a[i],a[j])==0) strcpy(a[j],""); for(i=0;i<=m;i++) if(strcmp(a[i],"")!=0) count++; cout<<count; return 0; }
0.0分
0 人评分