练习_统计词语

第三题:统计词语
输入一段含标点的英文语段(若干行,以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;


}


感觉写得不算完整,没有考虑分段的情况。

但是做到了将一段的文字中单词分别挑出存起来   然后将其排序。

排序的方法也有点笨拙  是用的之前学习的结构体里面定义小于符号和快速排序。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值