(一)工程设计时间预计

1.代码编写:2小时

  (1)文件夹的遍历以及筛选;

  (2)文件夹的读取,以及对读取字符的操作;

  (3)所得结果排序,以及文件输出。

2.程序调试:1小时

  (1)编写数据。

  (2)测试以及调试。

3.预计总时间:3小时

(二)工程所用实际时间

1.代码编写:4小时

  (1)文件夹的遍历以及筛选;

  (2)文件夹的读取,以及对读取字符的操作;

  (3)所得结果排序,以及文件输出。

2.程序调试:3小时

  (1)编写数据。

  (2)测试以及调试。

实际所用总时间:7小时

(三)关于实际时间比预计时间长的分析

  1. 在这一过程中对于文件的递归遍历始终无法做到,最终只能用cmd命令在windows环境下dir这个指令和列出文件目录有关
  2.  
  3. (四)程序部分代码
    遍历文件
  1. void Init(int argc,char *argv[]){
  2. string baseDir,command;
  3. baseDir=argv[argc-1];
  4. if (baseDir[baseDir.length()-]!='\\')
  5. baseDir+='\\';
  6. command="dir "+baseDir+"*.txt "+baseDir+"*.cpp "+baseDir+"*.h "+baseDir+"*.cs"+" /S"+" /B > result.txt";
  7. system(command.c_str());
  8. return;
  9. }

模式选择

  1. for(i=;i<(*count);i++){
  2. if(argc==){ //模式一
  3. for(k=;w[i].danci[k]!='\0'&&str[k]!='\0';k++)
  4. if(w[i].danci[k]!=str[k] && w[i].danci[k]+'A'-'a'!=str[k] && w[i].danci[k]!=str[k]+'A'-'a')
  5. break;
  6. if(w[i].danci[k]=='\0'&&str[k]=='\0'){
  7. flag1=;
  8. w[i].times++;
  9. if(w[i].danci[]>str[])
  10. strcpy_s(w[i].danci,str);
  11. break;
  12. }
  13. }
  14. else if(argc==){ //模式二
  15. int m,n;
  16. for(m=strlen(w[i].danci)-;m>=;m--)
  17. if(w[i].danci[m]>='a'&&w[i].danci[m]<='z' || w[i].danci[m]>='A' &&w[i].danci[m]<='Z')
  18. break;
  19. for(n=strlen(str)-;n>=;n--)
  20. if(str[n]>='a'&&str[n]<='z' || str[n]>='A'&&str[n]<='Z')
  21. break;
  22. if(m!=n)
  23. break;
  24. else{
  25. for(k=;k<=m;k++)
  26. if(w[i].danci[k]!=str[k] && w[i].danci[k]+'A'-'a'!=str[k] && w[i].danci[k]!=str[k]+'A'-'a')
  27. break;
  28. if(k=m+){
  29. flag1=;
  30. w[i].times++;
  31. if(strcmp(w[i].danci,str)>)
  32. strcpy_s(w[i].danci,str);
  33. break;
  34.  
  35. }
  36. }
  37. }
  38. }

(五)代码分析

1.分析报告

(六)所使用的测试用例

  1. 测试空文件夹

  1. 测试有相同单词的文件

  1. 测试有文件中包含文件的文件

  1. 测试有不符合后缀的文件

  1. 测试-e中数字不同,单词相同的文件

  1. 测试-e中大小写不同的文件

  1. 测试字母+数字+字母+数字的文件

(七)感想

这次的编程与预计差别非常大,让我了解了很多自己不懂得知识。通过网上搜索和查阅《c++prime》这本书让我了解了很多。

  1.  
  1.  

软件工程个人项目--Word frequency program的更多相关文章

  1. 软件工程个人项目-Word frequency program by11061167龚少波

    (一)工程设计时间预计 1.代码编写:4小时 熟悉Visual studio 2012的使用 : 程序代码部分主要分为三个步骤: (1)主函数的构建,包括各种函数调用及输入输出部分: (2)对目标文件 ...

  2. 关于软件工程个人作业 Word frequency program 的总结

    一.预计花在程序各部分的时间: (1)对所给命令行参数的判断和处理,看它是否合法.是哪种模式.预计用时20min; (2)关于目录操作:遍历给定目录下的所有文件,包括子目录和非目录文件.预计用时40m ...

  3. 【软件工程】Word frequency program

    一.开始写代码前的规划: 1.尝试用C#来写,之前没有学过C#,对于C++也不熟,所以打算先花1天的时间学习C# 2.整个程序基本分为文件遍历.单词提取.单词匹配.排序.输出几个模块,各个模块大致时间 ...

  4. Limeng:Individual Project: Word frequency program -BUAA Advanced Software Engineering

    11061190-李孟 Implement a console application to tally the frequency of words under a directory (2 mod ...

  5. Individual Project - Word frequency program——12061154Joy

    Description&Requirement: http://www.cnblogs.com/jiel/p/3978727.html 项目时间估计 理解项目要求: 1h 构建项目逻辑: 1h ...

  6. Individual Project - Word frequency program by HJB

    using System;using System.Collections.Generic;using System.IO;using System.Linq;using System.Text;us ...

  7. Individual Project - Word frequency program

    1.项目预计用时 -计划学习C#和百度一些用法的时间:5小时 -项目本身打算写两个类,一个是遍历搜索文件夹的,另外一个用来统计单词.计划用时:5小时 2.项目实际用时 学习C#以及正则表达式的用法:3 ...

  8. Individual Project - Word frequency program - Multi Thread And Optimization

    作业说明详见:http://www.cnblogs.com/jiel/p/3978727.html 一.开始写代码前的规划: 1.尝试用C#来写,之前没有学过C#,所以打算先花1天的时间学习C# 2. ...

  9. Record for Individual Project ( Word frequency program )

    1.  预计时间 ● 对问题总体的理解.规划:10 min ● 设计编写程序:5 h ● 调试: 分模块-40 min; 总体-40min ● 测试(性能分析).改进:1 h 2.  实际用时 ● 对 ...

随机推荐

  1. netty httpserver

    netty也可以作为一个小巧的http服务器使用. package com.ming.netty.http.httpserver; import java.net.InetSocketAddress; ...

  2. HBase学习笔记

    关键类: HBaseAdmin 管理Hbase的,主要负责DDL操作 HTable 管理表中数据,主要负责DML操作 1.为了避免热点,更多的建表方法 在Shell中: },{SPLITS=>[ ...

  3. LRU缓存算法

    http://blog.csdn.net/beiyeqingteng/article/details/7010411 http://blog.csdn.net/wzy_1988/article/det ...

  4. Android手机开机自动启动

    package com.example.x_yp.system_camera; import android.content.BroadcastReceiver; import android.con ...

  5. Codeforces Round #259 (Div. 2) C - Little Pony and Expected Maximum

    题目链接 题意:一个m个面的骰子,抛掷n次,求这n次里最大值的期望是多少.(看样例就知道) 分析: m个面抛n次的总的情况是m^n, 开始m==1时,只有一种 现在增加m = 2,  则这些情况是新增 ...

  6. web.xml元素介绍

    每一个站的WEB-INF下都有一个web.xml的设定文件,它提供了对我们站台的配置设定.web.xml中定义元素有:◆站台的名称和说明◆针对环境参数(Context)做初始化工作◆Servlet的名 ...

  7. LA 4329 (树状数组) Ping pong

    第一次写树状数组,感觉那个lowbit位运算用的相当厉害. 因为-x相当于把x的二进制位取反然后整体再加上1,所以最右边的一个1以及末尾的0,取反加一以后不变. 比如1000取反是0111加一得到10 ...

  8. UVa 10256 (判断两个凸包相离) The Great Divide

    题意: 给出n个红点,m个蓝点.问是否存在一条直线使得红点和蓝点分别分布在直线的两侧,这些点不能再直线上. 分析: 求出两种点的凸包,如果两个凸包相离的话,则存在这样一条直线. 判断凸包相离需要判断这 ...

  9. (转)c语言_链表实例讲解(两个经典例子)

    建立一个学生成绩的线性链表,对其实现插入,删除,输出,最后销毁. #include <stdio.h>#include <stdlib.h> struct grade {    ...

  10. AI 状态机

    by AKara 2010-11-11 @ http://blog.csdn.net/akara @ akarachen(at)gmail.com @weibo.com/akaras 一个简单横版游戏 ...