【Fantasy】第一次作业小结

时间:2022-03-02 16:32:47

第一次作业小结

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

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

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

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

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

【Fantasy】第一次作业小结
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;
                }
            }
【Fantasy】第一次作业小结

这些在以后做新程序或者对本程序进行改进的时候都要注意。