青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Fly me to the moon

the beauty of C++

基本算法練習(xí)(二)

這兩天狂累,研究報告、宣講會、見面會、筆試、面試所有的事情都連續(xù)在一起,忙得夠嗆,今天面完阿里研究院,總算有點時間了,于是先把上次提到的其它一些基本算法練習(xí)完成。
這次的練習(xí)包括:
原地堆排序,歸并排序,基于快排的選擇,計數(shù)排序,插值查找。

原地heap sort
使用最大堆,基于兩個堆的基本操作siftdown和siftup實現(xiàn)如下兩個步驟,事實上代碼里只用了siftdown,注意:這里的堆是從下標(biāo)0開始的數(shù)組,不同于一般的下標(biāo)從1開始的堆實現(xiàn)
(1)在輸入數(shù)組上原地建堆,O(N)
(2)N次"extractMax"操作,利用swap和siftdown實現(xiàn)
代碼里的parent和child是兩個宏,在下面的algo.h頭文件里聲明

 1//基本堆操作,注意:這里的堆從數(shù)組0位置開始!
 2//為了應(yīng)用堆排序,使用max堆
 3void sift_down(int a[], int i, int n)
 4{
 5    int temp, child;
 6    for(temp=a[i];left_child(i)<n;i=child)
 7    {
 8        child = left_child(i);
 9        if(child!=n-1 && a[child]<a[child+1])
10            child++;
11        if(temp<a[child])
12            a[i] = a[child];
13        else
14            break;
15    }

16    a[i] = temp;
17}

18
19void sift_up(int a[], int i, int n)
20{
21    int temp, p;
22    for(temp=a[i];i!=0;i=p)
23    {
24        p = parent(i);
25        if(a[p]<temp)
26            a[i] = a[p];
27        else
28            break;
29    }

30    a[i] = temp;
31}

32
33//原地堆排序
34void heap_sort(int a[], int n)
35{
36    int i;
37    for(i=n/2;i>=0;i--)
38        sift_down(a, i, n);//build heap O(N)
39    for(i=n-1;i>0;i--)
40    {
41        swap(a[0], a[i]);
42        sift_down(a, 0, i);
43    }

44}

歸并排序
標(biāo)準(zhǔn)的非原地實現(xiàn),但是也有一點小優(yōu)化,在算法開始時就一次性開了和輸入數(shù)組同樣大小的數(shù)組來保存中間值,免去了遞歸merge時每次重開數(shù)組的開銷。
 1//歸并實現(xiàn)一
 2void merge1(int a[], int ta[], int l, int r, int rend)
 3{
 4    int lend=r-1, temp=l, num=rend-l+1;
 5    
 6    while(l<=lend && r<=rend)
 7        if(a[l]<=a[r])
 8            ta[temp++= a[l++];
 9        else
10            ta[temp++= a[r++];
11
12    while(l<=lend)
13        ta[temp++= a[l++];
14    while(r<=rend)
15        ta[temp++= a[r++];
16
17    for(int i=0;i<num;i++,rend--)
18        a[rend] = ta[rend];
19}

20
21//歸并排序?qū)崿F(xiàn)一
22void msort1(int a[], int ta[], int l, int r)
23{
24    int m;
25    if(l<r)
26    {
27        m = (l+r)/2;
28        msort1(a, ta, l, m);
29        msort1(a, ta, m+1, r);
30        merge1(a, ta, l, m+1, r);
31    }

32}

33
34//歸并排序?qū)崿F(xiàn)一
35void merge_sort1(int a[], int n)
36{
37    int *ta = new int[n];
38    msort1(a, ta, 0, n-1);
39    delete [] ta;
40}

select
基于快排的選擇算法,平均時間復(fù)雜度O(N),很實用的選擇算法
 1//基于快排思想的選擇算法
 2int select(int a[], int l, int r, int k)
 3{
 4    if(l>=r)
 5        return a[l];
 6
 7    int i=l,j=r+1;
 8    while(1)
 9    {
10        do i++while(i<=&& a[i]<a[l]);
11        do j--while(a[j]>a[l]);
12        if(i>j)
13            break;
14        swap(a[i], a[j]);
15    }

16    swap(a[l], a[j]);
17
18    if(k==j+1)
19        return a[j];
20    else if(k<=j)
21        return select(a, l, j-1, k);
22    else
23        return select(a, j+1, r, k);//注意,這兒不用改變k
24}

25
26int select_kth(int a[], int n, int k)
27{
28    //為了不改變原始數(shù)組,復(fù)制原始數(shù)組
29    int *ta = new int[n];
30    for(int i=0;i<n;i++)
31        ta[i] = a[i];
32    return select(ta, 0, n-1, k);
33    delete [] ta;
34}

計數(shù)排序
這里假設(shè)輸入數(shù)據(jù)的范圍在[0,20],書上說一般數(shù)值范圍在[0,100]的時候計數(shù)排序很實用,典型應(yīng)用,排序百分制的考試分?jǐn)?shù)
 1//計數(shù)排序,條件:輸入數(shù)據(jù)范圍0~20
 2void csort(int a[], int b[], int c[], int len)
 3{
 4    int i;
 5    for(i=0;i<len;i++)
 6        c[a[i]]++;
 7    for(i=1;i<=20;i++)
 8        c[i] = c[i]+c[i-1];
 9    for(i=len-1;i>=0;--i)
10    {
11        b[c[a[i]]-1= a[i];
12        c[a[i]]--;
13    }

14}

15void count_sort(int a[], int n)
16{
17    int *= new int[n];
18    int *= new int[21];
19    for(int i=0;i<=20;i++)
20        c[i] = 0;
21
22    csort(a, b, c, n);
23
24    for(int i=0;i<n;i++)
25        a[i] = b[i];
26
27    delete [] b;
28    delete [] c;
29}

插值查找
和二分查找一樣,插值查找算法需要輸入數(shù)據(jù)已排序,時間復(fù)雜度和曲線的彎曲度相關(guān)
 1//插值查找,post condition: 數(shù)組a已排序
 2int ip_search(int a[], int l, int r, int t)
 3{
 4    if(l>|| a[l]>|| a[r]<t)
 5        return -1;
 6
 7    int i = l + (t-a[l])/(a[r]-a[l]);
 8    if(a[i] == t)
 9        return i;
10    else if(a[i]<t)
11        return ip_search(a, i+1, r, t);
12    else
13        return ip_search(a, l, i-1, t);
14}

15int interpolation_search(int a[], int n, int t)
16{
17    return ip_search(a, 0, n-1, t);
18}

為了便于以后的繼續(xù)擴展,這次連同上次的代碼分到了.h和.cpp里。

方法聲明,algo.h
 1#ifndef _ALGO_H
 2#define _ALGO_H
 3
 4#include <iostream>
 5#include <fstream>
 6#include <sstream>
 7#include <string>
 8#include <cmath>
 9#include <iomanip>
10#include <vector>
11#include <deque>
12#include <list>
13#include <queue>
14#include <stack>
15#include <map>
16#include <algorithm>
17#include <limits>
18#include <utility>
19#include <ctime>
20#include <bitset>
21using namespace std;
22
23void bubble_sort(int[], int);
24void insert_sort(int[], int);
25void select_sort(int[], int);
26void quick_sort_1(int[], int);
27void quick_sort_2(int[], int);
28void quick_sort_3(int[], int);
29int binary_search_1(int[], intint);
30int binary_search_1(int[], intint);
31int rand_int(intint);
32void heap_sort(int[], int);
33void merge_sort1(int[], int);
35int select_kth(int[], intint);
36void count_sort(int[], int);
37int interpolation_search(int [], int);
38
39#define left_child(i) (2*(i)+1)
40#define parent(i) ((i-1)/2)
41
42inline void assign_array(int a1[], int a2[], int n)
43{
44    for(int i=0;i<n;i++)
45        a1[i] = a2[i];
46}

47
48inline void print_array(int a[], int n)
49{
50    for(int i=0;i<n;i++)
51        cout<<a[i]<<" ";
52    cout<<endl;
53}

54
55#endif

測試代碼,algo.cpp
 1#include "algo.h"
 2
 3int main()
 4{
 5    int origin_array[] = {3,2,6,9,11,2,3,8,4,5,3,8,19,1,11,7};
 6    int len = sizeof(origin_array)/sizeof(origin_array[0]);
 7    int *test_array = new int[len];
 8
 9    //測試heap sort
10    assign_array(test_array, origin_array, len);
11    print_array(test_array, len);
12    cout<<"heap sort"<<endl;
13    heap_sort(test_array, len);
14    print_array(test_array, len);
15    cout<<endl;
16        
17    //測試merge sort
18    assign_array(test_array, origin_array, len);
19    print_array(test_array, len);
20    cout<<"merge sort"<<endl;
21    merge_sort1(test_array, len);
22    print_array(test_array, len);
23    cout<<endl;
32    
33    //測試counting sort
34    assign_array(test_array, origin_array, len);
35    print_array(test_array, len);
36    cout<<"counting sort"<<endl;
37    count_sort(test_array, len);
38    print_array(test_array, len);
39    cout<<endl;
40
41    //測試interpolation search
42    print_array(test_array, len);
43    int t, loc;
44    cout<<"請輸入要查找的值: ";
45    cin>>t;
46    if((loc=interpolation_search(test_array, len, t))>=0)
47        cout<<"find "<<t<<" at location: "<<loc<<endl;
48    else
49        cout<<t<<" is not in the array"<<endl<<endl;
50
51    //測試select kth
52    int k;
53    assign_array(test_array, origin_array, len);
54    print_array(test_array, len);
55    cout<<"請輸入要查找的目標(biāo)值的序數(shù)(1表示第1小值,2表示第2小值 ctrl+z退出): ";
56    while(cin>>k)
57    {
58        cout<<"select kth"<<endl;
59        cout<<""<<k<<"小值為: "<<select_kth(test_array, len, k)<<endl;
60        cout<<"請輸入要查找的目標(biāo)值的序數(shù)(1表示第1小值,2表示第2小值 ctrl+z退出): ";
61    }

62    cout<<endl;
63
64    return 0;
65}

posted on 2009-09-28 20:36 翼帆 閱讀(821) 評論(0)  編輯 收藏 引用 所屬分類: 算法筆試/面試

導(dǎo)航

<2009年9月>
303112345
6789101112
13141516171819
20212223242526
27282930123
45678910

統(tǒng)計

常用鏈接

留言簿

隨筆分類

隨筆檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲风情在线资源站| 亚洲欧美亚洲| 国产区二精品视| 欧美另类女人| 久久久久国产精品麻豆ai换脸| 亚洲免费成人| 亚洲国产精品va在线看黑人| 久久不见久久见免费视频1| 夜夜精品视频| 在线精品视频一区二区| 国产欧美一区二区三区另类精品| 欧美激情一区二区三区在线| 久久亚洲精品伦理| 欧美在线观看日本一区| 亚洲免费中文字幕| 亚洲三级视频在线观看| 麻豆精品在线视频| 久久超碰97人人做人人爱| 亚洲无毛电影| 艳妇臀荡乳欲伦亚洲一区| 在线视频国内自拍亚洲视频| 国产日韩欧美综合在线| 国产精品久久久久久久久久妞妞| 欧美精品激情| 欧美理论电影在线观看| 欧美第一黄色网| 欧美69视频| 免费观看成人www动漫视频| 久久精品夜色噜噜亚洲a∨| 亚洲欧美日韩国产中文在线| 中文亚洲字幕| 一区二区三区四区五区在线| 夜夜夜精品看看| 亚洲免费观看高清完整版在线观看熊 | 欧美激情成人在线| 美女视频一区免费观看| 久热精品视频在线观看| 久久亚洲精品一区| 久久久噜噜噜久久中文字免| 久久久久久免费| 可以看av的网站久久看| 美国十次成人| 欧美黄色日本| 亚洲欧洲日本国产| 亚洲精品自在在线观看| 99国产精品久久久久久久久久 | 国产精品一区在线观看| 国产欧美va欧美不卡在线| 国产亚洲精品综合一区91| 国产午夜精品全部视频播放| 国产一区二区久久久| 国语精品一区| 亚洲国产精品尤物yw在线观看| 亚洲欧洲精品一区| 亚洲素人一区二区| 久久福利一区| 男人插女人欧美| 亚洲国产精品专区久久| 亚洲最新在线视频| 午夜日韩在线观看| 久久香蕉国产线看观看av| 欧美精品黄色| 国产精品自拍一区| 在线观看亚洲a| 99热这里只有精品8| 亚洲欧美日韩综合| 久热精品在线视频| 亚洲精品1234| 亚洲免费在线电影| 美女尤物久久精品| 欧美日韩免费区域视频在线观看| 国产精品免费一区豆花| 尹人成人综合网| 亚洲精品乱码久久久久久按摩观| 亚洲视频自拍偷拍| 欧美在线观看一区| 欧美激情91| 亚洲在线视频网站| 蜜桃久久精品一区二区| 国产精品久久久久久福利一牛影视| 韩国福利一区| 亚洲一区bb| 女仆av观看一区| 一本色道**综合亚洲精品蜜桃冫 | 亚洲国产成人av| 亚洲欧美激情精品一区二区| 久久九九久久九九| 欧美网站在线| 亚洲国产成人一区| 亚洲一区二区在线视频| 蜜月aⅴ免费一区二区三区| 亚洲精品免费在线播放| 欧美一级二级三级蜜桃| 欧美美女bb生活片| 亚洲第一区在线| 亚洲制服av| 亚洲韩国青草视频| 久久精品人人爽| 国产精品久久久久av免费| 亚洲欧洲另类国产综合| 久久久久国产一区二区三区| 一本综合精品| 欧美成人乱码一区二区三区| 韩国av一区二区三区四区| 亚洲欧美在线网| 亚洲精品视频在线播放| 老鸭窝91久久精品色噜噜导演| 国产精品一区二区三区四区| 亚洲视频一区在线| 亚洲国产福利在线| 久久精品99国产精品| 国产精品日韩| 亚洲永久免费av| 亚洲精品美女在线观看| 免费观看亚洲视频大全| 激情久久久久| 久久久久久久精| 欧美一级视频| 国产欧美一区二区三区久久人妖| 亚洲性视频网址| 亚洲精品影视| 欧美日韩成人一区| 亚洲精品视频在线观看免费| 欧美mv日韩mv国产网站| 久久久亚洲国产美女国产盗摄| 国产色婷婷国产综合在线理论片a| 亚洲一区二区影院| 日韩一区二区免费看| 欧美精品国产精品日韩精品| 亚洲精品婷婷| 亚洲精品午夜精品| 欧美日韩第一页| av成人免费在线观看| 91久久精品国产91久久性色| 欧美成人午夜激情在线| 亚洲人成人一区二区三区| 欧美激情一区二区三区| 欧美高清在线精品一区| 9色精品在线| 99xxxx成人网| 国产精品久久网站| 午夜在线电影亚洲一区| 午夜精品免费视频| 国产热re99久久6国产精品| 久久久精品国产免费观看同学| 久久精品久久综合| 亚洲高清免费在线| 91久久黄色| 欧美午夜精品一区| 久久国内精品自在自线400部| 欧美伊人久久久久久午夜久久久久| 国产亚洲欧美一区二区三区| 久久综合狠狠| 欧美激情精品久久久久| 亚洲一区高清| 久久不见久久见免费视频1| 在线观看亚洲| 亚洲精选视频免费看| 国产精品www994| 久久夜色精品国产亚洲aⅴ| 欧美成年人网| 亚洲免费在线播放| 欧美在线999| 亚洲免费激情| 亚洲男女毛片无遮挡| 在线成人免费视频| 日韩视频免费| 国内精品久久久久久| 亚洲国产小视频| 国产欧美精品一区aⅴ影院| 欧美成人午夜激情| 国产精品成人在线观看| 久久夜色精品亚洲噜噜国产mv | 亚洲欧美国产另类| 久久精品国产69国产精品亚洲| 亚洲欧洲日产国产网站| 亚洲一区二区三区三| 亚洲福利视频三区| 这里只有精品在线播放| 狠狠综合久久| 一本色道久久综合亚洲精品高清| 国产一区视频在线观看免费| 亚洲清纯自拍| 国内精品99| 一区二区三区四区五区精品| 在线观看成人一级片| 一区二区三区高清视频在线观看| 国模精品娜娜一二三区| 日韩视频免费观看高清完整版| 韩日精品在线| 亚洲在线观看免费视频| 亚洲理论电影网| 久久久久久亚洲综合影院红桃| 亚洲午夜伦理| 欧美91大片| 狂野欧美激情性xxxx欧美| 国产精品久久国产愉拍| 亚洲国产成人午夜在线一区| 国产自产2019最新不卡| 亚洲网站视频福利|