individual project1 12061183
1.项目预计用时
之前大二下学期的时候学过面向对象,当时老师叫我们写过一个统计目录下单词的程序,大致的思路是一样的。于是觉得这个程序并不难写。于是就在周末还很轻松地休息着不看程序,知道别的同学提醒才开始看题
下面是我的预计用时:
---遍历文件夹,得到里面的内容,一个小时。
---将字符串按三种要求进行分割,并且存入,统计每个单词出现的次数,并排序,5个小时
---输出到文件。半个小时
2.项目实际用时
仔细看了老师的要求之后,发现完全是老师下的一个迷糊阵,这个和以前的那个程序还是有很大的出入的,字符串的匹配问题比以前困难了许多,而且还涉及到了c#,本来以为可以用java写的。(表示c#c++没一个会的)同时要考虑到程序的性能问题,那就应该在单词存储,统计,频度排序那块下手,要用到dictionary,正则表达式等等,但是这些都是不会的,需要先学。花的时间就像流水一样= =
---遍历文件夹,得到里面的内容,放在一个字符串里,差不多用了一个小时。c#中文件的处理方式和java的不同,花了一些时间在文件的处理上。
---将字符串按三种要求进行分割,并且存入,统计每个单词出现的次数,并排序。加上学习各种语法所用到的时间,肯定不少于15个小时!!!!只能说坑爹的正则表达式。还有可恶的哈希表按关键字排序竟然不行,只能又改写成dictionary
---将字符输出到文件,对命令行参数进行处理,两个小时。
---自己在很多小想法上面走了弯路,浪费了很多时间。
3.项目分析和优化
在考虑项目优化问题方面,在写代码的时候,就想着要从频度排序,单词的检索两个方向去改进。对于单词的检索和频度的统计,我采用了Directory<String,count>存储。其中String是单词的小写模式,count是自己创建的一个类,含有number和word两个变量。number存储了实际要打印出来的字符串,word存储了单词的频度。采用table.OrderByDescending(r => r.Value.getnum()).ThenBy(r => r.Value.getdanci());进行排序,然后就可以根据要求得到输出。不知道是不是电脑原因,跑得竟然那么慢。。。
在相对较合理的时间内完成了较大文件的检索。
下面是有关函数的使用情况:

4.项目的测试用例:
a.测试能否正确分隔单词,以及是否对大小写不敏感


b.测试两个连续单词时,判断能否得到所有连续的两个单词,或是两个空格分隔的字符串是否为连续的两个单词等等


c.测试连续三个单词是否能够正确匹配,判断能否得到所有连续的两个单词,或是两个空格分隔的字符串是否为连续的三个单词等等


d.当有多个文件的时候,看前一个文件的最后一个词会不会和后面一个文件的前面的词构成连续的词


e:检测三个连续单词匹配统计是否正确,以及能否正确处理换行符,是否考虑重叠问题


f:是否支持空文件的检索
很显然,输出文件没有字符串的输出
g:测试汉字的识别情况,是否将汉字当成分隔符


h:连续两个词的统计问题


i:测试三个词的统计和分隔情况


j:统计大文件,由于文件比较大就不贴出来了,但是能够不崩溃就行,就是不知道统计是否正确

5.收获。
想起上一学年被各种科目虐的很惨,但是在学期末的时候,自己都会有点庆幸,能够有这些课鞭策自己去努力的学,充分掌握好自己的时间学到更多的东西。
刚开始写这个程序的时候,自己一点都不了解c#,于是先花了一些时间去熟悉c#,又应题目的要求,去看了一些关于正则表达式和哈希表有关方面的知识,然后开始写自己的代码。刚开始的时候以为排序要用到快排,又去把快排复习了一次。在学习新的知识的同时也巩固了以前学习的知识。很大的收获就是自己学习了正则表达式和哈希表的使用方法,这对程序的性能有很大的提高。
由于不了解c#的类库,自己开始去查相应的API文档,自己以前并没有这样的习惯。这几天发现多阅读API对自己有很大的好处,是个良好的学习习惯,希望自己在以后的编程中也能一直保持这个习惯。
计算机方面要学习的知识还真是多,只能默默说一句自己会努力地。。。
individual project1 12061183的更多相关文章
- last individual reading task 12061183叶露婷
http://www.cnblogs.com/yltyy/p/4025426.html 1.Different people deserve different tasks; Once team ro ...
- individual reading task ---12061183 叶露婷
Different people deserve different tasks; Once team roles are settled, there comes along a lot of ot ...
- Apple individual program 加入之后的玩法 官方资源
Apple individual program 加入之后的玩法 官方资源 0. 开发资源文档 0.1 开发文档: https://developer.apple.com/support/res ...
- Individual Project - Word frequency program-11061171-MaoYu
BUAA Advanced Software Engineering Project: Individual Project - Word frequency program Ryan Mao (毛 ...
- PacBio & BioNano (Assembly and diploid architecture of an individual human genome via single-molecule technologies)
Assembly and diploid architecture of an individual human genome via single-molecule technologies 文章链 ...
- JSU 2013 Summer Individual Ranking Contest - 5
JSU 2013 Summer Individual Ranking Contest - 5 密码:本套题选题权归JSU所有,需要密码请联系(http://blog.csdn.net/yew1eb). ...
- Android问题-XE5提示"[DCC Fatal Error] Project1.dpr(1): F1027 Unit not found: 'System.pas' or binary equivalents (.dcu/.o)"
问题现象:Checking project dependencies...Compiling Project1.dproj (Debug, Android)dcc command line for & ...
- 问题-[致命错误] Project1.dpr(1): Unit not found: 'System.pas' or binary equivalents (DCU,DPU)
问题现象:[致命错误] Project1.dpr(1): Unit not found: 'System.pas' or binary equivalents (DCU,DPU) 问题原因:由于删除D ...
- Socket.io 0.7 – Sending messages to individual clients
Note that this is just for Socket.io version 0.7, and possibly higher if they don’t change the API a ...
随机推荐
- SAP系统产品历史与分类
SAP R/1---实时会计辅助财务的系统,最早叫RF系统.由原来批处理系统(数据输入后,由服务器在特定的时间分批处理).创造性的变为输入马上由计算机处理. SAP R/2—创造性的使用“basis” ...
- 【Beta Scrum】冲刺!4/5
1. 今日完成情况 人员 学号 分工 是否完成 完成情况 胡武成 031502610 完成登录注册api,协助web端完成api Y 基本逻辑写完,短信部分还在修改中,预计明天早上便能完成 郭剑南 0 ...
- Nginx主程序使用介绍
守护进程和服务 <br\>在首次运行Nginx之前,了解此应用程序的性质很重要. 有两种类型的计算机应用程序 – 那些需要用户输入,因此在前台运行,另一种在后台运行. Nginx是后一种类 ...
- Ubuntu18.04安装Tensorflow+cuda+cuDNN
本文写的比较简单,期间遇到的一些小麻烦,自己不认为成为阻碍,所以没有详细写. 如有疑问可以联系QQ:2922530320 Pycharm Pycharm使用Anaconda Pycharm 在新建项目 ...
- vue学习路由嵌套
1. 路由嵌套和参数传递 传参的两种形式: a.查询字符串:login?name=tom&pwd=123 {{$route.query}} ------ <li><route ...
- centos7搭建filebeat
filebeat的环境搭建 cd /home/elk wget https://artifacts.elastic.co/downloads/beats/filebeat/filebeat-6.2.4 ...
- docker镜像的创建commit及dockerfile
在docker 1.3版本以前使用attach进入容器会经常出现卡死的情况,之后官方退出了exec命令,从宿主机进入,但是从其他远程主机进入使用ssh服务来维护是用户熟悉的方法.所以这里来创建一个带有 ...
- Android 解决启动页白屏或者黑屏的问题
欢迎页启动的线程由于请求和处理的数据量过大而,导致欢迎页在出现之前界面上会有一个短暂的白色闪屏停留,当然白色闪屏的停留是因为 application 的主题样式android:theme=@style ...
- 不存在具有键“xxxId”的“IEnumerable<SelectListItem>”类型的 ViewData 项
项目中的某个页面,在访问时出现以下错误: 不存在具有键“xxxId”的“IEnumerable<SelectListItem>”类型的 ViewData 项 具体的场景说明如下: 一个编辑 ...
- 谈高清显示接口HDMI、RGB、LVDS、MIPI、eDP、mini-LVDS、V-By-One
近年来随着电子产业的高速发展,智能显示设备也取得了辉煌的成就,高清显示得到了消费者的青睐.目前高清显示协议接口有RGB.LVDS.MIPI.eDP.HDMI.miniLVDS.V-by-One等,由于 ...