cuitao42


私信TA

用户名:dotcpp0634607

访问量:497

签 名:

等  级
排  名 170
经  验 6976
参赛次数 0
文章发表 18
年  龄 10
在职情况 学生
学  校
专  业

  自我简介:

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 人评分

  评论区

  • «
  • »