本文档随时可能修改,并且没有另行通知。

请确保每一次在开始修改你的代码前,读标题中的日期,如果晚于你上次阅读,

请重读一次。

老五在寝室吹牛他熟读过《鲁滨逊漂流记》,在女生面前吹牛热爱《呼啸山庄》

《简爱》和《飘》,在你面前说通读了《战争与和平》。但是,他的四级至今没

过。你们几个私下商量,这几本大作的单词量怎么可能低于四级,大家听说你学

习《构建之法》,一致推举你写个程序名字叫wf,统计英文作品的单词量并给出

每个单词出现的次数,准备用于打脸老五。

希望实现以下效果。以下效果中数字纯属编造,。

功能1. 小文件输入. 为表明程序能跑,结果真实而不是迫害老五,请他亲自键

盘在控制台下输入命令。

>type test.txt
My English is very very pool. >wf -s test.txt
total 5 very 2
my 1
english 1
is 1
pool 1

为了评估老五的词汇量而不是阅读量,total一项是不重复的单词的个数,出现2

次的very计数1次。

此功能完成后你的经验值+10.

功能2. 支持命令行输入英文作品的文件名,请老五亲自录入。

>wf gone_with_the_wand
total 1234567 words the 5023
a 4783
love 4572
fire 4322
run 3822
cheat 3023
girls 2783
girl 2572
slave 1322
buy 822

此功能完成后你的经验值+30. 输入文件最大不超过40MB. 如果你的程序中途崩

了,会被老五打脸,不增加经验值。

功能3. 支持命令行输入存储有英文作品文件的目录名,批量统计。

>dir folder

gone_with_the_wand

runbinson

janelove

>wf folder

gone_with_the_wand

total 1234567 words

the    5023
a 4783
love 4572
fire 4322
run 3822
cheat 3023
girls 2783
girl 2572
slave 1322
buy 822
----
runbinson
total 1234567 words friday 5023
sea 4783
food 4572
dog 4322
run 3822
hot 3023
cood 2783
cool 2572
bible 1322
eat 822
----
janelove
total 1234567 words love 5023
chat 4783
lie 4572
run 4322
money 3822
inheritance 3023
class 2783
attribute 2572
data 1322
method 822

因为单词量巨大,只列出前10个单词的词频。

此功能完成后你的经验值+8.

功能4. 从控制台读入英文单篇作品,这不是为了打脸老五,而是为了向你女朋

友炫酷,表明你能提供更适合嵌入脚本中的作品(或者如她所说,不过是更灵活

的接口)。如果读不懂需求,请教师兄师姐,或者 google: linux 重定向,仅管

这个功能在windows下也有,搜索关键词中加入linux有利于迅速找到。

>wf -s < the_show_of_the_ring

total 176
the 6
a 3
festival 2
dead 2
for 2
...

>wf
A festival for the dead is held once a year in Japan. The festival is
a cheerful occation, for the dead are said to return to their homes
and they are welcomed by the living. total 176
the 6
a 3
festival 2
dead 2
for 2
...

要求 !,必选项。此项完成+50,此项不做-50.

参照《构建之法》表2-3和表2-4,为你的PSP表格第1列分类。

你的PSP表格中的第2列,即任务,可以是上述功能按你更细分的子功能。

要求1,发布你对每个功能 (或/和子功能)的预计花费时间,时间颗粒度不得低

于小时。

要求2,发布记录词频统计项目的PSP表格,时间颗粒度要求分钟。

要求3,把PSP表格统计结果填入表2-3。

要求4,对比要求1和要求3中每项时间花费的差距,分析原因。

致谢

感谢沈柏杉指出命令行的输入和输出没有用不同的格式排版,因此容易令人误解。目前此缺欠仍未修正。

感谢张金生指出 test.txt 词汇计数的错误。

词频统计 SPEC 20160911的更多相关文章

  1. 词频统计 SPEC 20170914 1 1 1 1 1

    功能1 小文件输入,为表明程序能跑,结果真实而不是迫害老五,请他亲自键盘在控制台下输入命令. #include<stdio.h> #include<string.h> #inc ...

  2. 【week2】 词频统计第一次更新

    词频统计: 对每个功能预计时间: 功能 预计(min) 实际(min) 数据流读入 20 40 正则规范字符串 15 20 排序 30 45 输出 20 30 其他   25 词频统计psp 日期 类 ...

  3. 软工结对项目之词频统计update

    队友 胡展瑞 031602215 作业页面 GitHub 具体分工 111500206 赵畅:负责WordCount的升级,添加新的命令行参数支持(自定义输入输出文件,权重词频统计,词组统计等所有新功 ...

  4. 软工之词频统计器及基于sketch在大数据下的词频统计设计

    目录 摘要 算法关键 红黑树 稳定排序 代码框架 .h文件: .cpp文件 频率统计器的实现 接口设计与实现 接口设计 核心功能词频统计器流程 效果 单元测试 性能分析 性能分析图 问题发现 解决方案 ...

  5. 论文爬取 & 词频统计2.0

    一.Github地址      课程项目要求    队友博客 二.具体分工 031602225 林煌伟 :负责C++部分主要功能函数的编写,算法的设计以及改进优化 031602230 卢恺翔 : 爬虫 ...

  6. 【第二周】Java实现英语文章词频统计(改进1)

    本周根据杨老师的spec对英语文章词频统计进行了改进 1.需求分析: 对英文文章中的英文单词进行词频统计并按照有大到小的顺序输出, 2.算法思想: (1)构建一个类用于存放英文单词及其出现的次数 cl ...

  7. 词频统计 ——Java

    github地址 :https://github.com/NSDie/personal-project 一.计划表 PSP2.1 Personal Software Process Stages 预估 ...

  8. 作业3-个人项目<词频统计>

    上了一天的课,现在终于可以静下来更新我的博客了.       越来越发现,写博客是一种享受.来看看这次小林老师的“作战任务”.                词频统计 单词: 包含有4个或4个以上的字 ...

  9. C语言实现词频统计——第二版

    原需求 1.读取文件,文件内包可含英文字符,及常见标点,空格级换行符. 2.统计英文单词在本文件的出现次数 3.将统计结果排序 4.显示排序结果 新需求: 1.小文件输入. 为表明程序能跑 2.支持命 ...

随机推荐

  1. October 21st 2017 Week 42nd Saturday

    Only I can change my life. No one can do it for me. 只有我可以改变我的命运,没有人可以帮我做. Stop complaining about the ...

  2. [BZOJ 1568][JSOI2008]Blue Mary开公司

    [BZOJ 1568][JSOI2008]Blue Mary开公司 题意 \(n\) 次操作, 维护一个一次函数集合 \(S\). 有两种操作: 给定 \(b\) 和 \(k\), 向 \(S\) 中 ...

  3. Springboot整合log4j2日志全解

    目录 常用日志框架 日志门面slf4j 为什么选用log4j2 整合步骤 引入Jar包 配置文件 配置文件模版 配置参数简介 Log4j2配置详解 简单使用 使用lombok工具简化创建Logger类 ...

  4. Oracle_spatial的空间索引

    空间索引 1.空间索引的创建 1)创建索引之前总是要为空间层插入元数据 2)如果之前创建的索引失败了,必须先删除才能创建 Drop index customers_sidx; 创建索引: Create ...

  5. C#实现的协同过滤算法

    using System;using System.Collections.Generic;using System.Linq;using System.Text; namespace SlopeOn ...

  6. Odoo附件传输

    转载请注明原文地址:https://www.cnblogs.com/cnodoo/p/9307319.html  一:odoo后端上传附件 odoo中的ir.attachment模型是附件模型,可以用 ...

  7. kubernetes 垃圾回收机制

    一:前言 Kubernetes系统在长时间运行后,Kubernetes Node会下载非常多的镜像,其中可能存在很多过期的镜像.同时因为运行大量的容器,容器推出后就变成死亡容器,将数据残留在宿主机上, ...

  8. <Android 开源库> PhotoPicker 从头到脚

    1. 简介 PhotoPicker, 是一款开源的图片选择器.效果上和微信相似. 2. 使用方法 2.1 添加依赖 dependencies { compile 'me.iwf.photopicker ...

  9. 理解传说中的roll、yaw、pitch

    三维中 Yaw, pitch and roll 的区分(图片)                    yaw 航偏                                         pi ...

  10. Error at offset之反序列化

    关于PHP 序列化(serialize)和反序列化(unserialize)出现错误(Error at offset)的解决办法. 首先我们分析一下为什么会出现这个错误: 编码问题 UTF-8: AN ...