您的位置:首页 > 其它

【Fantasy】第一次作业小结

2012-10-17 19:51 176 查看
第一次作业小结

因为没有VC12,性能测试暂时无法进行。但是从我自己的角度来看,程序还是有很多问题的。

1.未采用结构体,导致空间冗余,设置变量为1000,当单词种类(不是总量)大于1000时将不得不修改才能使用。而单词频率统计应该在大规模文件中才更有价值。

2.采用了选择排序而不是快速排序,在排序上的效率不高。

3.判断是否为单词的语句到最后才应用,直接导致前面有大量“无用功”。

4.search部分代码采用了goto语句,这不是一个好习惯。



public void search(string c)   //遍历及统计函数
{
DirectoryInfo DI = new DirectoryInfo(文件路径.SelectedPath);
String 字符串 = String.Empty;
foreach (var File in DI.GetFiles("" + c + "", SearchOption.AllDirectories))
{
using (StreamReader 流 = new StreamReader(File.FullName))
{
字符串 = 流.ReadToEnd();
}
string[] 单词 = 字符串.Split(' ', ',', '.', '<', '>', ':', ';', '/', '?', '[', ']', '{', '}', '!', '@', '#', '$', '%', '^', '&', '*', '(', ')', '-', '_', '+', '=', '|', '\'', '\"', '\\', '\r', '\n');
for (int i = 0; i < 单词.Count(); i++)
{
for (int j = 0; j <= k; j++)
if (string.Compare(单词[i], a[j], true) == 0)
{
number[j]++;
goto S;
}
a[k] = 单词[i];
number[k] = 1;
k++;
S: continue;
}
}




这些在以后做新程序或者对本程序进行改进的时候都要注意。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: