多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > php開源 > php教程 > 算法分析:快速選擇

算法分析:快速選擇

來源:程序員人生   發布時間:2017-01-13 10:50:19 閱讀次數:2749次

使用類似快速排序的方法,找出第k小的元素。

k從0開始的。

使用了快速排序的部份函數 快速排序

    //快速選擇
    template<typename Comparable>
    Comparable& quickSelect(vector<Comparable>& a, int left, int right, int k)
    {
        if (left + 10 <= right)//這個子數組大于10,繼續使用快速排序
        {
            Comparable pivot = median3(a, left, right);//關鍵值
            int i = left;//i指向左側
            int j = right - 1;//j指向右側,現在i和j都是已比較過的了,等下是先++和--
            while (true)
            {
                while (a[++i] < pivot) {}//小于關鍵值的元素是1直放在左側,找出1個大的元素
                while (pivot < a[--j]) {}//大于關鍵值的元素是1直放在右側,找出1個小的元素
                if (i < j)
                {
                    swap(a[i], a[j]);//i和j還沒有交匯,交換位置
                }
                else
                {
                    break;//這個時候i指向的數是應當比關鍵值大的了
                }
            }
            swap(a[i], a[right - 1]);//將關鍵值放在i的位置
            if (k <= i)
            {
                return quickSelect(a, left, i - 1, k);//k在左側的子序列中
            }
            else if(k > i + 1)
            {
                return quickSelect(a, i + 1, right, k);//k在右側的子序列中
            }
            else
            {
                return a[i];
            }
           
        }
        else
        {
            //使用插入排序,數組大小小于10的時候
            insertionSort(a.begin() + left, a.begin() + right + 1);
            return a[k];//由于排序是在全部數組里面的,所以第k位置就是所要的值
        }
    }
    
    template<typename Comparable>
    Comparable& quickSelect(vector<Comparable>& a, int k)
    {
        return quickSelect(a, 0, a.size() ⑴, k);
    }


生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 亚洲欧美国产精品久久久 | 亚洲国产欧美一区 | jizz亚洲| 亚洲小视频在线 | 欧美一区二区三区日韩免费播 | 狠狠色噜噜狠狠狠狠五月婷 | 欧美色交 | 三级爱爱视频 | 午夜三级网 | 国产精品亚洲欧美日韩区 | 久久96国产精品久久久 | 欧美日韩中文亚洲另类春色 | 日本不卡在线视频 | 亚洲成人中文 | 久久精品一区二区三区资源网 | 国内精品18videosex性欧美 | 国产在线一区二区视频 | 日本艳鉧动漫1~6中文在线观看 | 久操视频网站 | 亚洲小说区图片区另类春色 | 日韩欧美一区黑人vs日本人 | 小说区视频区图片区 | 噜噜噜私人影院 | 中文字幕在线免费视频 | 免费一区二区三区四区 | 日韩高清免费观看 | 日韩欧美一级a毛片欧美一级 | 黄色大全免费看 | 亚洲在线看片 | 日韩欧美印度一级毛片 | 欧美一区二区三区精品 | 伊人久久大香线焦在观看 | 看片在线麻豆免费 | 日本护士xxww免费 | 另类一区 | 男女上下爽无遮挡午夜免费视频 | 国产精品成aⅴ人片在线观看 | 精品久久久久亚洲 | 名优写真一区二区在线 | 国产欧美日韩亚洲精品区2345 | 精品国产欧美精品v |