输入一段含标点的英文语段(若干行,以Ctrl+Z结束)
统计这段话中出现的所有词语
要求按字典顺序输出词语,每输出一个词换一行
样例输入就是一段话,输出就是这段话出现的所有词语(相同的词语只出现一次)
#include<stdio.h>
#include<algorithm>
#include<string.h>
using namespace std;
struct e{
char a[100];
bool operator <(const e &b)const{
int tmp=strcmp(a,b.a);
if(tmp!=0)return tmp<0;
}
}buf[1000];//单词的排序定义
int main(){
char str[100000];
int i;
gets(str);//输入文本
int x=0,y=0;
for(i=0;str[i]!=0;i++){
if(str[i]>='a'&&str[i]<='z'){
buf[x].a[y++]=str[i];
}
else if(str[i]>='A'&&str[i]<='Z'){
buf[x].a[y++]=str[i];
}
else{
if(y!=0){
buf[x].a[y]='\0';
x++;
y=0;
}
}
}//单词分别存储起来
sort(buf,buf+x);//排序
for(i=0;i<x;i++){
puts(buf[i].a);
}//输出
return 0;
}
感觉写得不算完整,没有考虑分段的情况。
但是做到了将一段的文字中单词分别挑出存起来 然后将其排序。
排序的方法也有点笨拙 是用的之前学习的结构体里面定义小于符号和快速排序。