HDU 2072 单词数 详细解答
题目
单词数
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 单词数 详细解答的更多相关文章
- HDU 2072 - 单词数 - [(有点小坑的)字典树模板题]
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2072 Problem Descriptionlily的好朋友xiaoou333最近很空,他想了一件没有 ...
- hdu 2072 单词数(字符串)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2072 题意 每行输入由小写字母和空格组成,统计每行中不同的单词数. 题解 题解一 比较简洁的解法,读入 ...
- HDU 2072 单词数
题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=2072 普通解法: /* HDU 2072 单词数 --- 字符串处理 */ #include < ...
- HDU 2072(单词数)题解
以防万一,题目原文和链接均附在文末.那么先是题目分析: [一句话题意] “就是统计一篇文章里不同单词的总数”(已经是一句话了..) [题目分析] 明显需要去重,上set,因为按行分析,又没有EOLN用 ...
- 单词数 HDU 2072 字符串输入控制
单词数 HDU 2072 字符串输入控制 题意 lily的好朋友xiaoou333最近很空,他想了一件没有什么意义的事情,就是统计一篇文章里不同单词的总数.下面你的任务是帮助xiaoou333解决这个 ...
- C++实现文件内字符数、单词数、行数的统计
先给出github上的代码链接以及项目需求 1. 项目简介 这个项目的需求可以概括为:对程序设计语言源文件统计字符数.单词数.行数,统计结果以指定格式输出到默认文件中,以及其他扩展功能,并能够快速地处 ...
- 《c程序设计语言》读书笔记--统计 行数、单词数、字符数
#include <stdio.h> int main() { int lin = 0,wor = 0,cha = 0; int flag = 0; int c; while((c = g ...
- Linux - wc统计文件行数、单词数或字节数
一 wc简单介绍 wc命令用来打印文件的文本行数.单词数.字节数等(print the number of newlines, words, and bytes in files).在Windows的 ...
- JSU省赛队员选拔赛个人赛1(Coin Change、Fibbonacci Number、Max Num、单词数、无限的路、叠筐)
JSU省赛队员选拔赛个人赛1 一.题目概述: A.Coin Change(暴力求解.动态规划) B.Fibbonacci Number(递推求解) C.Max Num(排序.比较) D.单词数 ...
随机推荐
- vs下手敲git命令补遗
大多数常用的点按钮就行了.少数还是手敲方便 ng new myapp 的时候已经新建git了,不过只有master分支. 创建新分支可以点vs左下角分支名字,然后在上方弹出的命令行里写名字,不过鼠 ...
- VSAN Cluster Failed
failed message:AdVanced vSAN configuration in syncChecks if all of the hosts in a vSAN cluster have ...
- PHP消息队列之Beanstalk
Beanstalk,一个高性能.轻量级的分布式内存队列
- English trip -- VC(情景课)5 B Places around town 城市设施
Vocabulary focus 核心词汇 drugstore 药店: pill n. 药丸:弹丸,子弹:口服避孕药 medicine n. 药:医学:内科:巫术 hos ...
- 23 正则表达式和re模块
一.正则1.字符组 [a-zA-Z0-9]字符组中的 [^a] 除了字符组的 2. 3. 4. 二.re模块 re.S 设置 .的换行 obj=re 1.ret=re.search(正则,conten ...
- hdu 6395 Sequence (简单矩乘)
P/n大多数情况是不变的, 取值只有$O(\sqrt{P})$种, 可以用$p/(p/i)$跳过重复的值, 复杂度$O(logn\sqrt{P})$ 要注意 P跟模数P有冲突 要特判p/i==0和p/ ...
- NuGet 控制台代码
安装 Bootstrap 包:Install-package -version 3.0.0 bootstrap -projectname SportsStore.WebUI 这三句常常连用,在不同项目 ...
- JavaScript学习总结(十二)——JavaScript编写类
在工作中经常用到JavaScript,今天总结一下JavaScript编写类的几种写法以及这几种写法的优缺点,关于JavaScript编写类的方式,在网上看到很多,而且每个人的写法都不太一样,经常看到 ...
- POJ 1847 Floyd_wshall算法
前面用dijstra写过了.但是捏.数据很小.也可以用Floyd来写. 注意题目里给出的是有向的权值. 附代码:#include<stdio.h>#include<string.h& ...
- beaglebone-black reference url
reference : https://github.com/beagleboard/beaglebone-black/wiki/System-Reference-Manual https://bea ...