排序的基本概念和分类

排序算法

排序算法(英语:Sorting algorithm)是一种能将一串数据依照特定排序方式进行排列的一种算法

排序算法分类

排序算法通常被分类为:

  • 计算的时间复杂度(最差、平均、和最好性能),依据列表(list)的大小({\displaystyle n}n)。一般而言,好的性能是(大O符号),坏的性能是。对于一个排序理想的性能是,但平均而言不可能达到。基于比较的排序算法对大多数输入而言至少需要
  • 内存使用量(以及其他计算机资源的使用)
  • 稳定性:稳定排序算法会让原本有相等键值的纪录维持相对次序。也就是如果一个排序算法是稳定的,当有两个相等键值的R和S,且在原本的列表中R出现在S之前,在排序过的列表中R也将会是在S之前。
  • 依据排序的方法:插入、交换、选择、合并等等。

内排序与外排序

  • 内排序:在排序整个过程中待排序的所有记录全部被放置在内存中。
  • 外排序:在排序整个过程中需要在内外存之间多次交换数据。

我会在后续具体总结各类排序算法及其优化,并附有完整的C++实现代码,其中可能会频繁用到一些函数,打包到Utils类中作为static函数,使用类名进行调用,下面是Utils.h和Utils.cpp(随时可能补充)。

  • Utils.h
#ifndef UTILS_H
#define UTILS_H
class Utils{
    public:
        static void printArray(int* A, int n);
        static void swap(int* arr, int index1, int index2);
        static int* generateArray(int len, int range);
};
#endif
  • Utils.cpp
#include <iostream>
#include <random>
#include <time.h>
#include "Utils.h"
using std::default_random_engine;
using std::uniform_int_distribution;
using std::cout;
using std::endl;

void Utils::printArray(int* A, int n){
    if(A==NULL || n==0)
        return;
    for(int i=0; i<n; i++){
        cout<<A[i]<<" ";
    }
    cout<<endl;
}

void Utils::swap(int* arr, int index1, int index2){
    int tmp = arr[index1];
    arr[index1] = arr[index2];
    arr[index2] = tmp;
}

int* Utils::generateArray(int len, int range){
    if(len<1)
        return NULL;
    int *arr = new int[len];
    default_random_engine e;
    e.seed(time(NULL));
    uniform_int_distribution<int> u(0, range);
    for(int i=0; i<len; i++){
        arr[i] = u(e);
    }
    return arr;
}

PS

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值