//快速排序 #include<iostream> #include<fstream> using namespace std; #define MAXSIZE 20 //顺序表的最大长度 #define OK 0 #define ERROR -1 typedef char* InfoType; typedef struct { int key;//关键字项 InfoType otherinfo;//其他数据项 }RedType;//记录类型 typedef struct { RedType r[MAXSIZE+1];//r[0]闲置或用做哨兵单元 int length;//顺序表长度 }SqList;//顺序表类型 //初始化一个空的顺序表L void InitSqList(SqList &L) { L.length = 0; } //将待排序记录依次插入顺序表L void InsertSqList(SqList &L,ifstream& in) { int n;//待排序记录的个数 in>>n; if(n > MAXSIZE) exit(ERROR); for(int i=1; i<=n; ++i) { in>>L.r[i].key; ++L.length; } } //打印顺序表L void show(SqList L) { for(int i=1; i<=L.length; ++i) cout<<L.r[i].key<<" "; cout<<endl; } //对顺序表L中的子序列L.r[low..high]进行划分,返回枢轴的位置 //以L.r[low]作为枢轴 int Partition(SqList &L,int low,int high) { /*-------------代码开始------------------*/ L.r[0]=L.r[low]; pivotkey=L.r[low].key; while(low<high) { while(low<high&&L.r[high].ke>=piovtkey) --high; L.r[low]=L.r[high]; while(low<high&&L.r[low].key<=piovtkey) ++low; } L.r[low]=L.r[0]; return low; /*-------------代码结束------------------*/ } //对顺序表L中的子序列L.r[low..high]做快速排序 //要求调用show函数打印每一趟划分的结果 void QSort(SqList &L,int low,int high) { /*-------------代码开始------------------*/ if(low<high) pivotloc=Partition(L,low,high); QSort(L,low,pivotloc-1); Qsort(L,pivotloc+1,high); /*-------------代码结束------------------*/ } //对顺序表L做快速排序 void QuickSort(SqList &L) { show(L);//打印初始待排序序列 QSort(L,1,L.length); } int main() { ifstream in("data/测试数据.txt");//测试数据 SqList L; InitSqList(L); InsertSqList(L,in); QuickSort(L); return OK; }优化这段代码
时间: 2024-04-06 16:28:46 浏览: 58
这段代码本身没有明显的错误,但是可以进行一些优化:
1. 在 Partition 函数中,可以将枢轴的选择改为随机选择,避免最坏情况下的时间复杂度。
2. 在 QSort 函数中,可以加入一个判断条件,当子序列长度小于等于某个阈值时,使用插入排序代替快速排序,因为插入排序在小规模数据上的效率更高。
3. 在 InsertSqList 函数中,可以将读入数据的操作改为一次性读入整个文件,而不是逐个读取每个数值,这样可以减少 IO 操作的次数,提高效率。
4. 在 QuickSort 函数中,可以加入一个判断条件,当序列本身已经有序时,直接返回,避免不必要的递归操作。
相关问题
#include <iostream> #include <vector> #include <fstream> using namespace std; #include <boost/timer.hpp>
这段代码是一个C++程序的头文件部分,它包含了三个标准库的头文件和一个boost库的头文件。具体介绍如下:
1. `#include <iostream>`:这是C++标准库中的头文件,用于输入输出操作。它包含了一些常用的输入输出流对象,如`cin`和`cout`。
2. `#include <vector>`:这是C++标准库中的头文件,用于定义和操作动态数组(向量)。`vector`是一个模板类,可以存储任意类型的元素,并提供了方便的方法来访问和修改这些元素。
3. `#include <fstream>`:这是C++标准库中的头文件,用于文件输入输出操作。它提供了一些类和函数,可以方便地读写文件。
4. `#include <boost/timer.hpp>`:这是boost库中的头文件,用于计时器功能。boost是一个流行的C++扩展库,提供了许多高效且易于使用的功能和工具。
#include <iostream> #include <fstream> #include <vector> #include <string> using namespace std; //
这是一段C++程序的头文件部分,包含了一些标准库的头文件,具体介绍如下:
1. iostream:提供了输入输出流的基本功能,如cin、cout等。
2. fstream:提供了文件操作相关的功能,如读写文件等。
3. vector:提供了可变大小数组的功能,可以方便地进行动态管理。
4. string:提供了字符串相关的功能,如字符串的拼接、截取等。
其中,using namespace std; 表示使用标准命名空间,可以简化程序中的代码。
阅读全文