[关闭]
@rg070836rg 2015-09-10T16:01:36.000000Z 字数 5579 阅读 2021

数据结构课程设计报告

课程设计


课题:排序算法、演示及飞机订票系统
姓名:陈实
学号:19130216
班级:191302
指导教师:陈波


一、排序算法

任务描述:利用c++生成100W个随机数,并实现归并,快排,希尔以及堆排序,记录排序结果及时间等。

1.1、生成随机数

利用c#中的种子生成器,通过文件流保存至相应文件夹。

  1. private void range()
  2. {
  3. string path = Directory.GetCurrentDirectory();//获取当前目录
  4. path += "/RawData.txt";//文件名
  5. Random example = new Random();//种子生成器
  6. //MessageBox.Show(path);//测试路径是否正确
  7. using (StreamWriter sw = File.CreateText(path))
  8. {
  9. for (int i = 0; i < number; i++)
  10. {
  11. int tmp = example.Next(1, 65536);
  12. sw.WriteLine(tmp);
  13. }
  14. MessageBox.Show("已生成" + number/10000 + "万个随机数");
  15. }
  16. ReadFile(filedata, path);
  17. }

1.2、文件读取与存储

文件流读取文件与存储文件

  1. private void ReadFile(int[] f, String path)
  2. {
  3. using (StreamReader sr = File.OpenText(path))
  4. {
  5. string s = "";
  6. int i = 0;
  7. while ((s = sr.ReadLine()) != null)
  8. {
  9. int tmp = int.Parse(s);
  10. f[i++] = tmp;
  11. }
  12. }
  13. }
  14. private void SaveFile(int[] f, String path)
  15. {
  16. using (StreamWriter sw = File.CreateText(path))
  17. {
  18. for (int i = 0; i < f.Length; i++)
  19. {
  20. sw.WriteLine(f[i]);
  21. }
  22. }
  23. }

1.3、排序gui界面控件的代码设置

四个算法类似

  • 若未检测到生成随机数,则生成随机数
  • 利用跑表来测程序时间
  • 通过文件流拷贝文件数据
  • 排序程序
  • 显示结果
  • 其他几个类似
  1. private void ShellSort_Click(object sender, EventArgs e)
  2. {
  3. if (filedata[1] == 0)
  4. {
  5. range();
  6. }
  7. Stopwatch stopWatch = new Stopwatch();//跑表
  8. int[] shell_copy = new int[filedata.Length];//拷贝原始数据
  9. filedata.CopyTo(shell_copy, 0);
  10. stopWatch.Start();
  11. Shell(shell_copy);
  12. stopWatch.Stop();
  13. string path = Directory.GetCurrentDirectory();//获取当前目录
  14. path += "/" + DateTime.Now.ToString("yyyyMMdd"); ;
  15. Directory.CreateDirectory(path);
  16. String name = "ShellRes_runtime_";
  17. name += stopWatch.Elapsed.Milliseconds + "ms_";
  18. name += DateTime.Now.ToString("yyyyMMdd");
  19. name += DateTime.Now.ToString("HHmmss");//获取当前时间,用于创建文件夹
  20. name += ".txt";
  21. path += "/" + name;//获取写入目录
  22. SaveFile(shell_copy, path);//写入文件
  23. String res = "希尔排序执行完毕,执行时间:" + stopWatch.Elapsed.Milliseconds + "ms," + "结果保存至当前目录";
  24. hint h = new hint();
  25. h.setstr(res);
  26. h.Show();
  27. }

1.4、排序过程

1.4.1、希尔排序

间隔递减的插入排序

  1. private void Shell(int[] r)
  2. {
  3. int n = r.Length;
  4. for (int d = n; d >= 1; d = d / 2)
  5. {
  6. for (int i = d; i < n; i++)
  7. {
  8. int j;
  9. int temp = r[i]; //暂存被插入记录
  10. for (j = i - d; j >= 0 && temp < r[j]; j = j - d)
  11. r[j + d] = r[j]; //记录后移d个位置
  12. r[j + d] = temp;
  13. }
  14. }
  15. }

1.4.2、快速排序

  1. private int Partition(int[] r, int i, int j)
  2. {
  3. int temp = r[i];
  4. while (i < j)
  5. {
  6. while (i < j && r[j] >= temp)
  7. j--;
  8. if (i < j)
  9. r[i++] = r[j];
  10. while (i < j && r[i] <= temp)
  11. i++;
  12. if (i < j)
  13. r[j--] = r[i];
  14. }
  15. r[i] = temp;
  16. return i;
  17. }
  18. void Quick(int[] r, int i, int j)//快速排序算法QuickSort
  19. {
  20. if (i < j)
  21. {
  22. int pivot = Partition(r, i, j);
  23. Quick(r, i, pivot - 1);
  24. Quick(r, pivot + 1, j);
  25. }
  26. }

1.4.3、堆排序

  1. private void sift(int[] array, int target, int tail)
  2. {
  3. int tmp;
  4. int child = target * 2;
  5. while (child <= tail)
  6. {
  7. if (child + 1 <= tail && array[child] < array[child + 1])
  8. {
  9. child++;
  10. }
  11. if (array[child] <= array[target])
  12. {
  13. break;
  14. }
  15. if (array[child] > array[target])
  16. {
  17. tmp = array[child];
  18. array[child] = array[target];
  19. array[target] = tmp;
  20. target = child;
  21. child = child * 2;
  22. }
  23. }
  24. }
  25. void Heap(int[] r)//堆排序Heap
  26. {
  27. int len = r.Length;
  28. for (int i = len / 2; i >= 0; i--)
  29. {
  30. sift(r, i, len - 1);
  31. }
  32. //sorted and adjust
  33. int tmp, tail;
  34. for (int i = 0; i < len - 1; i++)
  35. {
  36. tail = len - 1 - i;
  37. tmp = r[tail];
  38. r[tail] = r[0];
  39. r[0] = tmp;
  40. sift(r, 0, tail - 1);
  41. }
  42. }

1.4.4、归并排序

  1. void merge(int[] array, int start, int mid, int end)
  2. {
  3. int[] tmpArray = new int[end - start + 1];
  4. int i = start;
  5. int j = mid + 1;
  6. int k = 0;
  7. while (i <= mid && j <= end)
  8. {
  9. if (array[i] <= array[j])
  10. {
  11. tmpArray[k++] = array[i++];
  12. }
  13. else
  14. {
  15. tmpArray[k++] = array[j++];
  16. }
  17. }
  18. while (i <= mid)
  19. {
  20. tmpArray[k++] = array[i++];
  21. }
  22. while (j <= end)
  23. {
  24. tmpArray[k++] = array[j++];
  25. }
  26. i = 0;
  27. while (start <= end)
  28. {
  29. array[start++] = tmpArray[i++];
  30. }
  31. }
  32. void Merge(int[] array, int start, int end)
  33. {
  34. if (start < end)
  35. {
  36. int mid = (start + end) / 2;
  37. Merge(array, start, mid);
  38. Merge(array, mid + 1, end);
  39. merge(array, start, mid, end);
  40. }
  41. }

1.5、程序测试

1.5.1、主界面展示

主界面展示

1.5.2、生成随机数界面

生成随机数界面

1.5.3、一万测试数据

(1)
一万测试数据1
(2)
一万测试数据2

1.5.4、十万测试数据

(1)
十万测试数据1
(2)
十万测试数据2

1.5.5、百万测试数据

(1)
百万测试数据1
(2)
百万测试数据2

1.6、结果目录展示

此处输入图片的描述

1.7、数据结果分析

万级别上,各排序速度相仿,均在几毫秒之内完成内存排序,
十万级别及百万级别上,随机数生成的测试文件,快速排序表现尤其好。
测试数据范围:1~65535

二、飞机管理系统

2.1、问题描述

  1. 任务:通过此系统可以实现如下功能:
  2. 录入:可以录入航班情况(数据可以存储在一个数据文件中,数据结构、具体数据自定)
  3. 查询:可以查询某个航线的情况(如,输入航班号,查询起降时间,起飞抵达城市,航班票价,票价折扣,确定航班是否满仓);
  4. 可以输入起飞抵达城市,查询飞机航班情况;
  5. 订票:(订票情况可以存在一个数据文件中,结构自己设定)
  6. 可以订票,如果该航班已经无票,可以提供相关可选择航班;
  7. 退票: 可退票,退票后修改相关数据文件;
  8. 客户资料有姓名,证件号,订票数量及航班情况,订单要有编号。
  9. 修改航班信息:当航班信息改变可以修改航班数据文件

2.2、问题解析

  • 问题不难,即一个管理系统,本文采用c#做gui界面,数据结构是可变数组。

  • 文件操作,仿照数据库操作,即用即读,不再在加载界面时读入内存。

  • 本文主界面共提供了8个按钮,分三组为:航班管理,票务管理以及系统。

2.3、航班管理

2.3.1、录入航班

  • 通过人工键入值,追加保存到文件末尾

2.3.2、删除航班

  • 从文件读取,并绑定到下拉列表框,提供显示与删除功能。并做了一定的安全测试。

2.3.3、修改航班

  • 从文件读取,并绑定到下拉列表框,提供显示与修改功能。并做了一定的安全测试。

2.3、票务管理

2.3.1、航班号订票

  • 已知航班号,从文件读取数据,输入相关信息,订票并写回文件,并做了一定的安全测试。

2.3.2、选择订票

  • 文件读取信息,绑定到控件,选择起始地与目的地订票,写回文件,并做了一定的安全测试。

2.3.3、退票

  • 文件读取信息,绑定到控件,选择客户ID,退票。

2.4、系统

2.4.1、退出系统

  • 提供退出程序的功能。

2.4.2、关于

  • 关于本软件的信息。

2.5、数据格式设计

2.5.1、航班数据

共9个字段,均为string型,方便操作。

  1. class Flight
  2. {
  3. public string FlightNumber;
  4. public string StartTime;
  5. public string EndTime;
  6. public string StartCity;
  7. public string EndCity;
  8. public string FlightTicket;
  9. public string TicketDisconut;
  10. public string MaxNumber;
  11. public string RestTicketNum;
  12. public Flight(string[] str)
  13. {
  14. if (str.Length != 9)
  15. {
  16. throw new Exception();
  17. }
  18. else
  19. {
  20. FlightNumber = str[0];
  21. StartTime = str[1];
  22. EndTime = str[2];
  23. StartCity = str[3];
  24. EndCity = str[4];
  25. FlightTicket = str[5];
  26. TicketDisconut = str[6];
  27. MaxNumber = str[7];
  28. RestTicketNum = str[8];
  29. }
  30. }
  31. public override string ToString()
  32. {
  33. string res = "";
  34. res +=
  35. FlightNumber +","+
  36. StartTime + "," +
  37. EndTime + "," +
  38. StartCity + "," +
  39. EndCity + "," +
  40. FlightTicket + "," +
  41. TicketDisconut + "," +
  42. MaxNumber + "," +
  43. RestTicketNum;
  44. return res;
  45. }
  46. }

2.5.1、订单数据

共4个字段,均为string型,方便操作。

  1. class Order
  2. {
  3. public string FlightNumber;
  4. public string Ordernum;
  5. public string name;
  6. public string Id;
  7. public Order(string[] str)
  8. {
  9. if (str.Length != 4)
  10. {
  11. throw new Exception();
  12. }
  13. else
  14. {
  15. Ordernum = str[0];
  16. FlightNumber = str[1];
  17. name = str[2];
  18. Id = str[3];
  19. }
  20. }
  21. public override string ToString()
  22. {
  23. string res = "";
  24. res +=
  25. Ordernum + "," +
  26. FlightNumber + "," +
  27. name + "," +
  28. Id;
  29. return res;
  30. }
  31. }

2.6、软件测试

测试繁多,不宜展示,在测试的时候修复许多bug,一定程度上增强了软件的安全性。

2.6.1、软件主界面

软件主界面

2.6.2、录入航班

录入航班

2.6.3、删除航班

删除航班

2.6.4、修改航班

修改航班

2.6.5、航班号订票

航班号订票

2.6.6、目的地订票

目的地订票

2.6.7、退票

退票

三、排序演示

  • 本程序是基于MFC编写的,原框架是来源于VC课程,再次做了重构,提取出了方法,便于加类以实现不同的排序演示,在这里,介绍一个demo。
  • 程序采用绘制view和时钟中断,实现了模拟排序的效果。

3.1、csArray类

  1. 这是所有排序类的基类,其他排序类由此扩展,负责绘制一些基本的试图。

3.2、CTestView

  1. 视图类,控制时钟中段,建立排序类实例,绘制排序类等功能。

3.3、扩展排序类

  1. 目前实现了冒泡,插入,选择,希尔的演示

3.4、程序测试

3.4.1、程序主界面

程序主界面

3.4.2、冒泡排序

冒泡排序

3.4.3、插入排序

插入排序

3.4.4、选择排序

选择排序

3.4.5、希尔排序

希尔排序

四、课设心得

  • 更好的掌握数据结构
  • 更严谨的测试程序
  • 通过实际编译系统的分析设计、编程调试,掌握应用软件的分析方法和工程设计方法
  • 培养了我选用参考书,查阅手册及文献资料的能力。培养独立思考,深入研究,分析问题、解决问题的能力
  • 严肃认真的心态
添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注