题目

单词数

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. JSP中scope属性 scope属性决定了JavaBean对象存在的范围

    scope属性决定了JavaBean对象存在的范围. scope的可选值包括: ---page(默认值) ---request ---session ---application   1.page范围 ...

  2. 雷林鹏分享:Ruby 循环

    Ruby 循环 Ruby 中的循环用于执行相同的代码块若干次.本章节将详细介绍 Ruby 支持的所有循环语句. Ruby while 语句 语法 while conditional [do] code ...

  3. R & ggplot2 & Excel绘图(直方图/经验分布图/QQ图/茎叶图/箱线图)实例

    持续更新~ 散点图 条形图 文氏图 饼图 盒型图 频率直方图 热图 PCA图 3D图 火山图 分面图 分面制作小多组图 地图 练习数据: year count china Ame jap '12 2. ...

  4. 基于DOMContentLoaded实现文档加载完成后执行的方法

    我们有时可能需要一些在页面加载完成之后执行的方法,其实js原生就提供了onload方法,所以我们最简单的办法就是直接给onload赋值一个函数,在页面加载完成之后就会自动执行 widnow.onloa ...

  5. dp练习(3)——棋盘问题

    设有一个n*m的棋盘(2≤n≤50,2≤m≤50),如下图,在棋盘上有一个中国象棋马. 规定: 1)马只能走日字 2)马只能向右跳 问给定起点x1,y1和终点x2,y2,求出马从x1,y1出发到x2, ...

  6. vim 缩进设置

    1.在自己的家目录(/home)下建立.vimrc文件.控制台输入vi ~/.vimrc 回车. 2.在.vimrc文件中输入如下文本: set tabstop=4 set softtabstop= ...

  7. C# 格式化表

    C#格式化数值结果表 字符 说明 示例 输出 C 货币 string.Format("{0:C3}", 2) $2.000 D 十进制 string.Format("{0 ...

  8. U盘安装Ubuntu三步走

    需要工具: U盘.Ubuntu的ISO镜像.universal usb installer 1.下载Ubuntu (1) (2)我这里下载14.04版本 (3)我这里下载64位系统 下载后得到的是个t ...

  9. CentOS 7 Crontab

    Crontab默认每分钟读取 /etc/crontab 文件./etc/cron.d/目录和/var/spool/cron/目录一次,3者对应任务的建立格式是一致的,只是/var/spool/cron ...

  10. L1-012 计算指数

    真的没骗你,这道才是简单题 —— 对任意给定的不超过 10 的正整数 n,要求你输出 2​n​​.不难吧? 输入格式: 输入在一行中给出一个不超过 10 的正整数 n. 输出格式: 在一行中按照格式  ...