数据结构实训五——排序算法应用

简介: 数据结构实训五——排序算法应用

1.实验目的:

(1)熟练掌握常用的内排序方法并加以比较。

2.实验内容:

利用随机函数产生N个随机整数(20000以上),对这些数进行多种方法进行排序。要求:

(1)至少采用三种方法实现上述问题求解(提示,可采用的方法有希尔排序、起泡排序、快速排序、选择排序、堆排序)。并把排序后的结果保存在不同的文件中。

(2)统计每一种排序方法的性能(以上机运行程序所花费的时间为准进行对比),找出其中两种较快的方法。

3.实验代码:

#include<bits/stdc++.h>
using namespace std;
const int maxn=20000+100;
int a[maxn],n,b[maxn];
void sortloop(int n,int *b)
{
    for(int i=1; i<n; i++)
    {
        for(int j=i+1; j<=n; j++)
            if(b[i]>b[j]) swap(b[i],b[j]);
    }
}
void sortquick(int l,int r,int *b)
{
    if(l<r)
    {
        int val=b[l];
        int low=l,high=r;
        while(low<high)
        {
            while(b[high]>=val&&low<high) high--;
            b[low]=b[high];
            while(b[low]<=val&&low<high) low++;
            b[high]=b[low];
        }
        a[low]=val;
        sortquick(l,low-1,b);
        sortquick(low+1,r,b);
    }
}
void sortshell(int n,int *b){
    /*for(int gap=2*n;gap;gap=gap/2){
        for(int i=gap;i<=n;i++){
            for(int j=i-gap;j>=1;j-=gap){
                if(b[j]>b[j+gap]) swap(b[j],b[j+gap]);///不优化
            }
        }
    }*/
    for(int gap=2*n;gap;gap=gap/2){
        for(int i=1;i<=gap;i++){///gap组
            for(int j=i+gap;j<=n;j+=gap){
                if(b[j]<b[j-gap]){
                    int tmp=b[j],q=j-gap;
                    while(q>=1&&b[q]>tmp){
                        b[q+gap]=b[q];q-=gap;
                    }
                    b[q+gap]=tmp;
                }
            }
        }
    }
}
int main()
{
    srand(time(0));//随机数种子
    clock_t s,e;
    n=(rand()*rand()+rand())%20000+1;///随机生成数组的长度
    for(int i=1; i<=n; i++)
    {
        a[i]=(rand()*rand()+rand())%10000+1;///随机生成数组内的元素
        b[i]=a[i];///拷贝
    }
    cout<<"原数组的元素为:"<<endl;
     /*for(int i=1;i<=n;i++){
         cout<<a[i]<<" ";
         if(i%5==0) puts("");
     }*/
    ///选择排序 希尔排序 堆排序
    s=clock();///计算代码运行时间
    cout<<"冒泡排序后的元素为"<<endl;
    sortloop(n,b);
    /*for(int i=1;i<=n;i++){
        cout<<b[i]<<" ";
        if(i%5==0) puts("");
    }*/
    e=clock();
    cout<<"冒泡排序花费的时间为:"<<(double(e-s)/CLOCKS_PER_SEC)<<"s\n";
    s=clock();///计算代码运行时间
    cout<<"快速排序后的元素为"<<endl;
    for(int i=1; i<=n; i++) b[i]=a[i];
    sortquick(1,n,b);
    /*for(int i=1;i<=n;i++){
        cout<<b[i]<<" ";
        if(i%5==0) puts("");
    }*/
    e=clock();
    cout<<"快速排序花费的时间为:"<<(double(e-s)/CLOCKS_PER_SEC)<<"s\n";
    s=clock();///计算代码运行时间
    cout<<"希尔排序后的元素为"<<endl;
    for(int i=1; i<=n; i++) b[i]=a[i];
    sortshell(n,b);
    /*for(int i=1;i<=n;i++){
        cout<<b[i]<<" ";
        if(i%5==0) puts("");
    }*/
    e=clock();
    cout<<"希尔排序花费的时间为:"<<(double(e-s)/CLOCKS_PER_SEC)<<"s\n";
    return 0;
}
目录
相关文章
|
4天前
|
算法
数据结构中的KMP算法及其改进算法
KMP算法通过引入部分匹配表,有效避免了重复计算,从而将字符串匹配的时间复杂度降低到O(m+n)。通过进一步优化next数组,KMP算法的效率得到了进一步提升。对于大规模字符串匹配问题,KMP算法及其改进算法提供了高效的解决方案,是计算机科学领域的经典算法之一。
11 3
|
9天前
|
算法 计算机视觉
图像处理之积分图应用四(基于局部均值的图像二值化算法)
图像处理之积分图应用四(基于局部均值的图像二值化算法)
17 0
|
9天前
|
监控 算法 图计算
图像处理之积分图应用三(基于NCC快速相似度匹配算法)
图像处理之积分图应用三(基于NCC快速相似度匹配算法)
10 0
|
1天前
|
机器学习/深度学习 算法 C语言
详细介绍递归算法在 C 语言中的应用,包括递归的基本概念、特点、实现方法以及实际应用案例
【6月更文挑战第15天】递归算法在C语言中是强大力量的体现,通过函数调用自身解决复杂问题。递归涉及基本概念如自调用、终止条件及栈空间管理。在C中实现递归需定义递归函数,分解问题并设定停止条件。阶乘和斐波那契数列是经典应用示例,展示了递归的优雅与效率。然而,递归可能导致栈溢出,需注意优化。学习递归深化了对“分而治之”策略的理解。**
11 7
|
2天前
|
机器学习/深度学习 存储 算法
【机器学习】深入探索机器学习:线性回归算法的原理与应用
【机器学习】深入探索机器学习:线性回归算法的原理与应用
|
4天前
|
机器学习/深度学习 算法 前端开发
决策树与随机森林算法在分类问题中的应用
本文探讨了决策树和随机森林两种监督学习算法,它们在分类任务中表现出强大的解释性和预测能力。决策树通过特征测试进行分类,构建涉及特征选择、树生成和剪枝。随机森林是集成学习方法,通过构建多棵决策树并汇总预测结果,防止过拟合。文中提供了Python代码示例,展示如何使用sklearn构建和应用这些模型,并讨论了参数调优和模型评估方法,如交叉验证和混淆矩阵。最后,强调了在实际问题中灵活选择和调整模型参数的重要性。
19 4
|
5天前
|
机器学习/深度学习 存储 算法
PHP中的数据结构及其在机器学习中的应用
本文探讨了PHP在机器学习中的作用,强调了数据结构的重要性。文中列举了PHP中的常见数据结构,如数组、对象、字典、链表、树和图,并解释了它们在机器学习场景下的应用。例如,数组用于特征向量,对象封装模型,字典存储特征映射,链表和树实现特定算法。通过示例代码展示了如何使用这些数据结构进行特征标准化和模型预测。文章总结指出,PHP的数据结构为机器学习提供了有效工具,随着技术发展,PHP在数据处理领域的应用将持续扩展。
15 4
|
6天前
|
存储 算法 数据可视化
Dijkstra算法在《庆余年》中的应用:范闲的皇宫之旅
Dijkstra算法在《庆余年》中的应用:范闲的皇宫之旅
|
6天前
|
机器学习/深度学习 算法 大数据
【机器学习】朴素贝叶斯算法及其应用探索
在机器学习的广阔领域中,朴素贝叶斯分类器以其实现简单、计算高效和解释性强等特点,成为了一颗璀璨的明星。尽管名字中带有“朴素”二字,它在文本分类、垃圾邮件过滤、情感分析等多个领域展现出了不凡的效果。本文将深入浅出地介绍朴素贝叶斯的基本原理、数学推导、优缺点以及实际应用案例,旨在为读者构建一个全面而深刻的理解框架。
11 1
|
6天前
|
算法 数据挖掘 定位技术
算法必备数学基础:图论方法由浅入深实践与应用
算法必备数学基础:图论方法由浅入深实践与应用