排序算法集合——严蔚敏

// Win32_Console.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"

using namespace std;

#define MAXSIZE 20
#define MAXUINT ( (UINT)(~((UINT)0)) )
#define MAXINT ( (INT)(MAXUINT >>1) )
#define MININT ( (INT)(~MAXINT) )

typedef int KeyType;
typedef struct _RedType{
    KeyType key;
    int next;
    _RedType operator = ( _RedType& r){
        key=r.key;
        next=r.next;
        return (*this);
    }
    BOOL operator < ( _RedType& r ){
        return (key < r.key)?true:false;
    }

    BOOL operator > ( _RedType& r ){
        return (key > r.key)?true:false;
    }

}RedType;


///       插入(直接,折半,二路,表插入,希尔),交换(冒泡,快排),/
                /        选择(简单,树形,堆),归并,基数

typedef struct _Sqlist{
    RedType r[MAXSIZE+2];
    int length;

    _Sqlist(CString& str){
        int i=1;
        while(!str.IsEmpty()){
            int flag=str.Find(_T(" ") );
            r[i].key=_tstoi(str.Left(flag).GetBuffer() );
            if(flag<0){
                r[i].key=_tstoi(str.GetBuffer() );
                break;
            }
            str=str.Right(str.GetLength()-flag-1);
            i++;
        }
        length=i;
    };

    void print(){
        int i;
        for(i=1;i<length;i++)
            cout<<r[i].key<<" ";
        cout<<r[i].key<<endl;
    }

    void InsertSort(){                        //    直接插入排序    O(n^2)
        int i,j;
        for(i=2;i<length+1;i++){
            if(r[i]<r[i-1]){
                r[0]=r[i];
                r[i]=r[i-1];
                for(j=i-2;r[0]<r[j];j--)
                    r[j+1]=r[j];
                r[j+1]=r[0];
            }
        }
    }

    void BInsertSort(){                        //    折半插入排序   O(n^2)        减少了查找次数
        int i,j;
        for(i=2;i<length+1;i++){
            r[0]=r[i];
            int low=1,high=i-1,mid;
            while(low<=high){
                mid=(low+high)/2;
                if(r[mid]>r[0])
                    high=mid-1;
                else
                    low=mid+1;
            }
            for(j=i-1;j>=high+1;j--) r[j+1]=r[j];
            r[high+1]=r[0];
        }
    }

    void TwoPathInsertSort(){            //  2-路插入排序   O(n^2/8)
        int swap[MAXSIZE],i,j,first,final;
        swap[1]=r[1].key;
        final=1;
        first=length+1;
        swap[first]=MAXINT;
        for(i=2;i<=length;i++){
            if(r[i].key>swap[1]){            //左半边插入
                final++;
                j=final;
                while(r[i].key<swap[j-1]){
                    swap[j]=swap[j-1];
                    j--;
                }
                    swap[j]=r[i].key;
            }else{                            //右半边插入
                first--;
                j=first;
                while(r[i].key>swap[j+1]){
                    swap[j]=swap[j+1];
                    j++;
                }
                swap[j]=r[i].key;
            }
        }
        /  swap[]内的数据写入Sqlist  ///
        j=0;
        for(i=first;i<=length;i++){
            j++;
            r[j].key=swap[i];
        }
        for(i=1;j<=length;i++){
            j++;
            r[j].key=swap[i];
        }
    }
        
    void TableInsertSort(){                //  表插入排序   O(n^2)            最多3*(n-1)次移动。。。现行移动次数
        //第一步:排序
        r[0].next=1;r[0].key=MAXINT;
        r[1].next=0;
        int p,q;            指针
        int i;
        for(i=2;i<=length;i++){
            p=0;
            do{
                if(r[i] < r[ r[p].next ]){
                    r[i].next = r[p].next;
                    r[p].next=i;
                    break;
                }
                p=r[p].next;
            }while(1);
        }
        /第二步:重排
        p=r[0].next;
        for(i=1;i<length;i++){
            while(p<i)    p=r[p].next;
            q=r[p].next;
            if(p!=i){
                _RedType swap=r[p];
                r[p]=r[i];
                r[i]=swap;
                r[i].next=p;
            }
            p=q;
        }
    }

    void BubbleSort(){        //a ^=(b ^= (a ^= b));   ;        //最快O(n-1),交换0次;最慢O(n*(n-1)/2),交换相同次数
        int i,j;
        BOOL change=true;
        for(i=length;i>1 && change;i--){
            change = false;
            for(j=1;j<i;j++){
                if(r[j]>r[j+1]){
                    r[j].key ^=(r[j+1].key ^=(r[j].key ^=r[j+1].key) );
                    change=true;
                }
            }
        }
    }

    void SelectSort(){                            //选择排序
        int i,j,min;
        for(i=1;i<length;i++){
            min=i;
            for(j=i+1;j<=length;j++){
                if(r[min]>r[j])
                    min=j;
            }
            r[min].key ^=(r[i].key ^=(r[min].key ^=r[i].key) );
        }
    }


    void QuickSort(int low,int high){
        if(low>=high) return;
        int i,j;
        _RedType tmp;
        i=low;j=high;
        tmp=r[low];
        while(i<j){
            while(r[j]>=tmp && i<j) j--;
            r[i]=r[j];
            while(r[i]<=tmp && i<j) i++;
            r[j]=r[i];
        }
        r[i]=tmp;
       
        QuickSort(low,i-1);
        QuickSort(i+1,high);
    }
}Sqlist;


int main()
{
    Sqlist l(CString("49 38 65 97 76 13 27 49") );
    l.print();
    //l.InsertSort();
    //l.BInsertSort();
    //l.TwoPathInsertSort();
    //l.TableInsertSort();
    //l.BubbleSort();
    //l.SelectSort();

    l.QuickSort(1,l.length);
    l.print();

    return 0;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
数据结构及算法C语言版。严蔚敏版。VC6运行通过,这个是源代码CPP文件,包含顺序线性表、单链表的插入、删除、查找。包含监视哨查找,折半查找,直接插入排序,希尔排序,冒泡排序,快速排序,选择排序。里面包含超大量的注释,包括对VC6的语法解释和算法的解释和理解。具体效果可以看 http://download.csdn.net/detail/changechange/8236207 我上次上传的 EXE demo,带输入输出,能与用户交互。在运行的时候会把整个运算的过程都显示出来。摘录代码如下://数据结构 上机第一次 栈应用,转换进制题目。 //请用每一个cpp作为一个项目,不要把多个cpp放到同一个项目中,因为我为每个cpp都定义了main。 //这个教材上没有,只能自己补全了 #include using namespace std; //p10 #define TRUE 1 #define FALSE 0 #define OK 1 #define ERROR 0 #define INFEASIBLE -1 #define OVERFLOW -2 typedef int Status; //下面这行书上没找到,自己补的。 typedef int SElemType; //p46书上的。 #define STACK_INIT_SIZE 100 //定义最初申请的内存的大小 #define STACKINCREMENT 10 //每一次申请内存不足的时候扩展的大小 typedef struct { SElemType *base; //在栈构造之前和销毁之后,base的值为null SElemType *top; //栈顶指针 int stacksize; //当前已分配的存储空间,以元素为单位 }SqStack; //定义顺序栈别名。 //构造一个空栈S Status InitStack(SqStack &S) { // 参考之前的 List.cpp中队malloc的解释。 S.base=(SElemType *) malloc(STACK_INIT_SIZE * sizeof (SElemType)); if (!S.base) exit(OVERFLOW); // 存储分配失败 S.top = S.base; //初始时栈顶等于栈低 S.stacksize = STACK_INIT_SIZE; //初始栈容量 return OK; } //end of InitStack //插入元素e为新的栈顶元素 Status Push(SqStack &S, SElemType e) { if (S.top - S.base >= S.stacksize) // 栈满,追加存储空间 { S.base = (SElemType *) realloc(S.base, //原栈底指针 (S.stacksize + STACKINCREMENT) * sizeof (SElemType)); //新大小 if (!S.base) exit(OVERFLOW); // 存储分配失败 //调整栈顶的位置 S.top = S.base + S.stacksize; //修改栈大小为新的大小 S.stacksize += STACKINCREMENT; } //*符号为求值符。 *S.top++ = e; //先把e压入栈顶,S.top再增1指向栈顶元素e的下一个位置 return OK; } //end of Push // 若栈不空,则删除S的栈顶元素,用e返回其值,并返回OK;否则返回ERROR Status Pop(SqStack &S, SElemType &e) { if (S.top == S.base) //栈顶=栈底表示空栈,如果空栈,报错 return ERROR; e = *--S.top; //S.top先减1指向栈顶元素,再取值,赋值给e用于返回。 return OK; } //这个书上没有,自己加的 //书上没有,自己写的,用来处理每一个元素的data Status PrintEach(SElemType e){ cout<<e<<";"; return OK; } //从栈底依次对栈中每个元素调用函数visit(),主要用于输出 //关于visit的解释参考 List.cpp Status StackTraverse(SqStack &S,Status(* visit)(SElemType)){ int l = S.top-S.base; S.top=S.base; //从栈底开始输出 for(int i=0;i<l;i++) //用长度控制输出的个数 { (* visit)(*(S.top)++); } return OK; } // 若栈S为空栈,则返回TRUE,否则返回FALSE Status StackEmpty(SqStack &S) { //栈顶指针S.top是否等于栈底指针S.base是判断栈是否为空的条件 if (S.top == S.base) return TRUE; else return FALSE; } //p48 进行进制转换 //对于输入的任意一个非负十进制整数,打印输出与其等值的八进制数 void conversion() // 算法3.1 { SqStack S; //声明顺序栈S unsigned int N; //unsigned 表示无符号,unsigned int 从0开始,非负整数 SElemType e; //栈元素e InitStack(S); //构造空栈S cout<=0)"<<endl; scanf("%d",&N); //获取用户的输入,%d 是对数据的格式化。 &N 表示对变量 N 引用。 while (N) //只要n不等于0就循环。从n为用户输入的十进制数开始,一直到n等于0为止 { Push(S, N % 8); //n除以8的余数(8进制的低位)入栈 //先压入的余数是八进制的低位,后压入的余数是八进制的高位 N = N / 8; //令n等于n整除以8的商,进入下轮循环 } //我自己加的,先输出一遍栈内的内容。 cout<<"从底到顶输出栈内的内容,用于调试:"; StackTraverse(S,PrintEach); cout<<endl; //循环结束时,n等于0 while (!StackEmpty(S)) //只要栈S没pop空就不断循环,直到pop出栈底元素栈S为空为止 { Pop(S, e); //pop出栈顶元素且赋值给e进行返回 //先pop出的是八进制的高位,后pop出的是八进制的低位 printf("%d", e); //依次输出e } //循环结束时,栈S为空 cout<<endl; } int main() { for(int i=0;i<4;++i) conversion(); return 0; }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

夜猫逐梦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值