C++面试总结之算法(一):排序

排序有几种方式,分别介绍其实现原理?(问)

(1)冒泡排序

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

(2) 选择排序

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

 

(3) 快排(挖坑排序)(重要)

1. 右指针找比基准数小的,左指针找比基准数大的,交换之

2. 冒泡+二分+递归分治

void quickSort(int s[], int left, int right)  {  
    if (left < right)   {        
        int i = left, j = right, x = s[left];  
        while (i < j)   {  
            while(i < j && s[j]>= x) // 从右向左找第一个小于x的数  
                j--;   
            if(i < j)  
                s[i++] = s[j];  
            while(i < j && s[i]< x) // 从左向右找第一个大于等于x的数  
                i++;   
            if(i < j)  
                s[j--] = s[i];  
        }  
        
        s[i] = x;  
        quickSort(s, left, i - 1); // 递归调用  
        quickSort(s, i + 1, right);  
    }  
}  

为什么一定要j指针先动呢?首先这也不是绝对的,这取决于基准数的位置,因为在最后两个指针相遇的时候,要交换基准数到相遇的位置。一般选取第一个数作为基准数,那么就是在左边,所以最后相遇的数要和

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值