几个排序算法的比较

手写快排,算法练习题

借用SDL的库,来演示一下几个排序算法的效果:
依次测试了 "快排、选择、插入和冒泡"。

sort.gif

废话不多说直接上代码部分:

// Example program:
// Using SDL2 to create an application window

#include <SDL.h>
#include <stdio.h>
#include <time.h>


volatile char quit = 0;
SDL_Renderer *renderer;

void event_loop();

int init_array(int arr[],int len);
void quick_sort(int arr[],int len);
void selection_sort(int arr[], int len);
void insertion_sort(int arr[], int len);
void bubble_sort(int arr[], int len);

void reset();
void clear_screen();
void draw_chart(int arr[],int len);

void update_chart();

//Dsets g_sets[50];
int g_arr[50];
int g_arr_bck[50];
int g_len = 50;

int main(int argc, char* argv[]) 
{
    int i ;

    SDL_Window *window;                    // Declare a pointer

    SDL_Init(SDL_INIT_VIDEO);              // Initialize SDL2

    // Create an application window with the following settings:
    window = SDL_CreateWindow(
        "An SDL2 window",                  // window title
        SDL_WINDOWPOS_UNDEFINED,           // initial x position
        SDL_WINDOWPOS_UNDEFINED,           // initial y position
        640,                               // width, in pixels
        480,                               // height, in pixels
        SDL_WINDOW_OPENGL                  // flags - see below
    );

    // Check that the window was successfully created
    if (window == NULL) {
        // In the case that the window could not be made...
        printf("Could not create window: %s\n", SDL_GetError());
        return 1;
    }

    // The window is open: could enter program loop here (see SDL_PollEvent())


    renderer = SDL_CreateRenderer(window, -1, 0);
    clear_screen();

    init_array(g_arr,g_len);
    memcpy(g_arr_bck,g_arr,g_len*sizeof(int));

    draw_chart(g_arr, g_len);
    
    SDL_RenderPresent(renderer);
   
    event_loop();

    // Close and destroy the window
    SDL_DestroyWindow(window);

    // Clean up
    SDL_Quit();
    return 0;
}

void event_loop()
{

    SDL_Event e;

    while (!quit){
            while (SDL_PollEvent(&e)){
                if (e.type == SDL_QUIT){
                        quit = 1;
                }
                if (e.type == SDL_KEYDOWN){
                        //quit = 1;
                    clock_t chartStart = clock();
                    switch(e.key.keysym.sym) {
                        case SDLK_F1:
                            quick_sort(g_arr,g_len);
                            break;
                        case SDLK_F2:
                            selection_sort(g_arr,g_len);
                            break;
                        case SDLK_F3:
                            insertion_sort(g_arr,g_len);
                            break;
                        case SDLK_F4:
                            bubble_sort(g_arr, g_len);
                            break;
                        case SDLK_F10:
                            reset();
                            break;
                        default:
                            
                            break;
                    }
                    clock_t chartend = clock();
                    float ts = (float)(chartend - chartStart) /CLOCKS_PER_SEC;
                    printf("times:%f\n",ts);
                    
                }
                if (e.type == SDL_MOUSEBUTTONDOWN){
                        //quit = 1;
                }
               
            }
    }

}

void shuffle(int arr[],int len)
{
    int i=len;
    int tmp,n;
    while(i>1){
        n = rand()%i;
        tmp = arr[i-1];
        arr[i-1]=arr[n];
        arr[n]=tmp;
        i--;
    }
}

int init_array(int arr[],int len)
{
    int i ;
    if(arr == NULL) return -1;
    for(i=0;i<len;i++){
            arr[i]=i;
    }

    shuffle(arr,len);
    return len;
}

void reset()
{
    memcpy(g_arr,g_arr_bck,g_len*sizeof(int));
    update_chart();

}

void clear_screen()
{
    SDL_SetRenderDrawColor(renderer, 255, 255, 255, 255);
    SDL_RenderClear(renderer);
    
}

#define ORI_X 30
#define ORI_Y 200
#define ORI_W 10
#define ORI_H 3
void draw_chart(int arr[],int len)
{
    int i;
    clear_screen();
   
    for(i=0;i<len;i++){
        SDL_Rect rect;
        rect.x=ORI_X+i*ORI_W;
        rect.y=ORI_Y;
        rect.w=ORI_W-2;
        rect.h=arr[i]*ORI_H+1;
        
        SDL_SetRenderDrawColor(renderer, 255, 0, 255, 0);
        SDL_RenderFillRect(renderer,&rect);

    }
}



void update_chart()
{

    draw_chart(g_arr,g_len);
    SDL_RenderPresent(renderer);
    SDL_Delay(20);

}


//sorting
void swap(int *s,int *d)
{
        int tmp=*s;
        *s=*d;
        *d=tmp;
}

void quick_sort_recursive(int arr[],int start,int end)
{
        if(start>=end)
                return ;

        int mid=arr[end];
        int left=start,right=end-1;

        while(left<right){
            while(arr[left]<mid && left<right)
                left++;
            while(arr[right]>=mid && left<right)
                right--;
            swap(&arr[left],&arr[right]);
            update_chart();

        }

        if(arr[left]>=arr[end]){
            swap(&arr[left],&arr[end]);
            update_chart();
        }else
            left++;

        if(left)
            quick_sort_recursive(arr,start,left-1);

        quick_sort_recursive(arr,left+1,end);

}

void  quick_sort(int arr[],int len)
{
    //printf("quick_sort beging...\n");
    quick_sort_recursive(arr,0,len-1);
    printf("quick_sort over...\n");
}

void selection_sort(int arr[], int len)
{
    int i, j, min, temp;
    for (i = 0; i < len - 1; i++) {
        min = i;
        for (j = i + 1; j < len; j++)
            if (arr[min] > arr[j])
                min = j;
        temp = arr[min];
        arr[min] = arr[i];
        arr[i] = temp;
        update_chart();
    }
}

void insertion_sort(int arr[], int len)
{
    int i, j;
    int temp;
    for (i = 1; i < len; i++) {
        temp = arr[i];
        j = i - 1;
        
        for (; j >= 0 && arr[j] > temp; j--) {
            arr[j + 1] = arr[j];
            update_chart();
        }
        arr[j + 1] = temp; 
        
    }
}

void bubble_sort(int arr[], int len)
{
    int i, j, temp;
    for (i = 0; i < len - 1; i++)
        for (j = 0; j < len - 1 - i; j++)
            if (arr[j] > arr[j + 1]) {
                temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
                update_chart();
            }
}

Mac 下编译:

gcc window.c `sdl2-config --libs --cflags`

后续完善测试程序和其他排序算法的增加。

github 链接:https://github.com/touchao123/sorting_sdl.git

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容