题目

单词数

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. mapStateToProps,mapDispatchToProps的使用姿势

    本文作者:IMWeb 黄qiong 原文出处:IMWeb社区 未经同意,禁止转载 前言 刚接触redux的时候,发现大家对mapDispatchToProps使用有几种方法,而且都跑通了,本文来介绍下 ...

  2. Unity另外一套简单日志控制系统

    using UnityEngine; public class LogPrintf { static LogLevel logLevel = LogLevel.LOG_LEVEL_ERROR; pub ...

  3. C#使用xpath查找xml节点信息

    Xpath是功能很强大的,但是也是相对比较复杂的一门技术,最好还是到博客园上面去专门找一些专业的帖子来看一看,下面是一些简单的Xpath语法和一个实例,提供给你参考一下. xml示例: <?xm ...

  4. Apache配置文件httpd.conf细说

    1.httpd.conf文件位于apache安装目录/conf下2.Listen 88表示监听端口88 此处可以连续写多个端口监听如下: Listen 88 Listen 809 3.目录配置如下: ...

  5. android沉浸状态栏和顶部状态栏背景色的设置

    法一: 现在很多应用都引用了沉浸式状态栏,如QQ,效果下图: 这样的效果很酷炫,其实设置很简单. 不过要说明的是,这种效果只能在API19以及以上版本中才能够做到. 如果想让界面Activity中实现 ...

  6. Linux系统中切换用户身份su与sudo的用法与实例

    日常操作中为了避免一些误操作,更加安全地管理系统,通常使用的用户身份都为普通用户,而非root.当需要执行一些管理员命令操作时,再切换成root用户身份去执行. 普通用户切换到root用户的方式有:s ...

  7. 新建 ASP.NET MVC 项目快速代码

    视图模型- PagingInfo 类: public class PagingInfo { public int TotalItems { get; set; } public int ItemsPe ...

  8. EBS 中iSupplier模块中的MAPPING_ID

    在EBS的供应商模块中,有一个非常有意思的表 POS_SUPPLIER_MAPPINGS, 这个表中建立了supplier_reg_id,vendor_id,party_id之间的映射关系. 这个表中 ...

  9. maven相关资源

    http://mvnrepository.com/search?q= http://maven.aliyun.com/nexus/#welcome https://www.w3cschool.cn/m ...

  10. winRAR显示树树目录

    这样 比较方便