题目

单词数

Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)

Total Submission(s): 46370 Accepted Submission(s): 11363

Problem Description

lily的好朋友xiaoou333最近很空,他想了一件没有什么意义的事情,就是统计一篇文章里不同单词的总数。下面你的任务是帮助xiaoou333解决这个问题。

Input

有多组数据,每组一行,每组就是一篇小文章。每篇小文章都是由小写字母和空格组成,没有标点符号,遇到#时表示输入结束。

Output

每组只输出一个整数,其单独成行,该整数代表一篇文章里不同单词的总数。

Sample Input

you are my friend

#

Sample Output

4

代码

AC代码:

#include<stdio.h>
#include<string.h>
int main()
{
char s[10000],m[100][100],n[100];
int i,sum,k,t,q;
while(gets(s)){
q=k=t=0;
if(s[0]=='#') break;
for(i=0;s[i]!='\0';i++){
if(s[i]!=' '){
m[k][t++]=s[i];
if(s[i+1]==' '||s[i+1]=='\0'){
m[k][t]='\0';
t=0;
k++;
}
}
}
q=k;
for(i=0;i<q-1;i++){
t=i;
for(k=i+1;k<q;k++)
if(strcmp(m[t],m[k])>0)
t=k;
strcpy(n,m[t]);
strcpy(m[t],m[i]);
strcpy(m[i],n);
}
sum=q;
for(i=0;i<q-1;i++)
if(strcmp(m[i],m[i+1])==0)
sum--;
printf("%d\n",sum);
}
return 0;
}

详细题解

之前写的一道题目,现在看了之后让我坚定了写注释和注意写变量名的含义了,比如计数可用count,求和用sum,temp…具有特征性的变量。

下面详细地说明该段代码地含义:

 char s[10000],m[100][100],n[100];

s存储你输入一段小文章,m是下面给小文章中单词一个个剥离的存储数组,n的作用是下面给单词排序是互换的中间值,打个比方:

temp=a;

a=b;

b=temp;

其作用是相当于temp.

if(s[0]=='#') break;   

满足题目中的输入#结束输入

for(i=0;s[i]!='\0';i++){
if(s[i]!=' '){
m[k][t++]=s[i];
if(s[i+1]==' '||s[i+1]=='\0'){
m[k][t]='\0';
t=0;
k++;
}
}
}

这是很重要的一段,通过空格字符和结束符将文章中的单词一个个分开,并存入二维数组中,二维数组每行代表一个单词。

 for(i=0;i<q-1;i++){
t=i;
for(k=i+1;k<q;k++)
if(strcmp(m[t],m[k])>0)
t=k;
strcpy(n,m[t]);
strcpy(m[t],m[i]);
strcpy(m[i],n);
}

这段是将单词按不同字母的码值大小排序,说明白点就是将分离的一个个单词按照英语字典中的顺序排序,其中便用到了n;

 for(i=0;i<q-1;i++)
if(strcmp(m[i],m[i+1])==0)
sum--;
printf("%d\n",sum);

删除其中重复的单词。

还有需要注意的是string.h 库中函数的使用,strcmp比较字符串大小,strcpy赋值字符串。

注释过的代码

以下再放我加过注释的AC代码:

#include<stdio.h>
#include<string.h>
int main()
{
char s[10000],m[100][100],n[100];
int i,sum,k,t,q;
while(gets(s)){ //s作为文章存储单位
q=k=t=0;
if(s[0]=='#') break; //如果输入#,程序结束
for(i=0;s[i]!='\0';i++){ //从数组【0】开始遍历,知道字符结束符\0为止
if(s[i]!=' '){ //二维数组,讲一个单词与一个单词分开,储存在不同的行数组
m[k][t++]=s[i];
if(s[i+1]==' '||s[i+1]=='\0'){ //如果下个字符为空格或者结束符,则在数组存入结束符
m[k][t]='\0';
t=0;
k++;
}
}
}//通过以上代码讲单词与单词分开,并且在其后加上字符结束符
q=k; //简单判断下,单词的个数
for(i=0;i<q-1;i++){//一个一个单词进行遍历
t=i;
for(k=i+1;k<q;k++)
if(strcmp(m[t],m[k])>0)//t=i,k=i+1,so k=t+1 将单词按英汉字典排序方式进行分类,方便下面的遍历
t=k;
strcpy(n,m[t]);
strcpy(m[t],m[i]);
strcpy(m[i],n);//将m[t]与m[i]的字符串交换
}
sum=q;
for(i=0;i<q-1;i++)
if(strcmp(m[i],m[i+1])==0)//如果 m[i],m[i+1]相等,单词总数sum相应的减去一
sum--;
printf("%d\n",sum);
}
return 0;
}

所以一定要注意注释的使用,方便后来的阅读

HDU 2072 单词数 详细解答的更多相关文章

  1. HDU 2072 - 单词数 - [(有点小坑的)字典树模板题]

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2072 Problem Descriptionlily的好朋友xiaoou333最近很空,他想了一件没有 ...

  2. hdu 2072 单词数(字符串)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2072 题意 每行输入由小写字母和空格组成,统计每行中不同的单词数. 题解 题解一 比较简洁的解法,读入 ...

  3. HDU 2072 单词数

    题目链接  http://acm.hdu.edu.cn/showproblem.php?pid=2072 普通解法: /* HDU 2072 单词数 --- 字符串处理 */ #include < ...

  4. HDU 2072(单词数)题解

    以防万一,题目原文和链接均附在文末.那么先是题目分析: [一句话题意] “就是统计一篇文章里不同单词的总数”(已经是一句话了..) [题目分析] 明显需要去重,上set,因为按行分析,又没有EOLN用 ...

  5. 单词数 HDU 2072 字符串输入控制

    单词数 HDU 2072 字符串输入控制 题意 lily的好朋友xiaoou333最近很空,他想了一件没有什么意义的事情,就是统计一篇文章里不同单词的总数.下面你的任务是帮助xiaoou333解决这个 ...

  6. C++实现文件内字符数、单词数、行数的统计

    先给出github上的代码链接以及项目需求 1. 项目简介 这个项目的需求可以概括为:对程序设计语言源文件统计字符数.单词数.行数,统计结果以指定格式输出到默认文件中,以及其他扩展功能,并能够快速地处 ...

  7. 《c程序设计语言》读书笔记--统计 行数、单词数、字符数

    #include <stdio.h> int main() { int lin = 0,wor = 0,cha = 0; int flag = 0; int c; while((c = g ...

  8. Linux - wc统计文件行数、单词数或字节数

    一 wc简单介绍 wc命令用来打印文件的文本行数.单词数.字节数等(print the number of newlines, words, and bytes in files).在Windows的 ...

  9. JSU省赛队员选拔赛个人赛1(Coin Change、Fibbonacci Number、Max Num、单词数、无限的路、叠筐)

    JSU省赛队员选拔赛个人赛1 一.题目概述: A.Coin Change(暴力求解.动态规划)     B.Fibbonacci Number(递推求解) C.Max Num(排序.比较) D.单词数 ...

随机推荐

  1. Python - os 文件/目录操作

    最近经常用到 os 操作文件/目录,感觉挺好使的,但是一直没有系统的梳理学习一下, 今天想借此机会整理一下工作中常用的方法,也算自己总结学习的一个积累吧. 直接上代码,注释明了 #-*-coding: ...

  2. 检验二叉树序列化的合理性 Verify Preorder Serialization of a Binary Tree

    2018-07-31 17:47:13 问题描述: 问题求解: 本题要求在不构建二叉树的情况下对先序遍历生成的序列化字符串进行合法性验证,这里有个技巧性较强的验证方法,就是采用当前可用的指针数目进行验 ...

  3. 雷林鹏分享:Ruby 字符串(String)

    Ruby 字符串(String) Ruby 中的 String 对象存储并操作一个或多个字节的任意序列,通常表示那些代表人类语言的字符. 最简单的字符串是括在单引号(单引号字符)内.在引号标记内的文本 ...

  4. Linux : 密码正确不能正常登陆,日志提示Could not get shadow information for user

    今天,再玩Centos7的时候,尝试修改了下ssh的端口.因为默认开启了SELinux,如果没有修改这个文件配置就修改端口sshd服务就不能正常启动了. 但是,当我修改会22端口的时候还是不能正常登陆 ...

  5. _beginthreadex()和CreateThread()的区别

    在本例子中我们使用——beginThreadex这个函数,它和createThread的区别是: 为了方便管理,我么在使用该函数的时候可以把它的线程函数作为类成员,这也就需要在类中把该函数变成静态函数 ...

  6. Hibernate---介绍

    Hibernate---介绍 框架体系结构: 2hibernate入门 1.1 ORM框架 Hibernate是一个数据持久化层的ORM框架. Object:对象,java对象,此处特指JavaBea ...

  7. Scrum介绍——续

    四. Scrum过程 Scrum的过程如图4-1所示 图4-1 Scrum过程 4.1 建立Product Backlog Product Backlog是Product Owner把客户的商业需求按 ...

  8. elasticsearch配置详解

    一.说明 使用的是新版本5.1,直接从官网下载rpm包进行安装,https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-5 ...

  9. Memcached 扩展常用方法

    保存数据 向memcached保存数据的方法有 add replace set 它们的使用方法都相同: $add = $memcached->add( '键', '值', '期限' ); $re ...

  10. 玩转X-CTR100 l STM32F4 l ADC 模拟数字转换

    我造轮子,你造车,创客一起造起来!塔克创新资讯[塔克社区 www.xtark.cn ][塔克博客 www.cnblogs.com/xtark/ ]      本文介绍X-CTR100控制器 AD转换接 ...