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

posts - 183,  comments - 10,  trackbacks - 0

二分查找的變形

傳統的二分查找
數組時有序的,要么升序要么降序,這里不考慮重復元素出現的情況。

int foo(int a[], int n, int item)
{
    
int left = 0, right = n - 1;
    
int middle = 0;
    
while (left <= right)
    {
        middle 
= (left + right) / 2;
        
if (item > a[middle])
        {
            left 
= middle + 1;
        }
        
else if (item < a[middle])
        {
            right 
= middle - 1;
        }
        
else
        {
            
return middle;
        
        }
    }
    
return -1;
}

 


二分查找的變形
給定一個數組 int a[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
如果對該數組調整為
{6, 7, 8, 9, 10, 1, 2, 3, 4, 5}
調整后即是兩個連續有序序列,只不過整體不有序
還是用二分策略,但是具體細節需要改進
整體結構還是一樣的
具體補充的是當待查找元素與中間元素不相等時,
如果小于,還要檢測 item 與 a[left] 的大小關系
如果大于,還要檢測 item 與 a[right] 的大小關系

int bar(int a[], int n, int item)
{
    
int left = 0, right = n - 1;
    
int middle = 0;
    
while (left <= right)
    {
        middle 
= (left + right) / 2;
        
if (item < a[middle])
        {
            
if (a[left] < item)
            {
                right 
= middle - 1;
            }
            
else if (a[left] > item)
            {
                left 
= middle + 1;
            }
            
else
            {
                
return left;
            }
            
// right = middle - 1;
        }
        
else if (item > a[middle])
        {
            
if (a[right] > item)
            {
                left 
= middle + 1;
            }
            
else if (a[right] < item)
            {
                right 
= middle - 1;
            }
            
else
            {
                
return right;
            }
        }
        
else
        {
            
return middle;
        }
    }
    
return -1;
}

 1 #include <iostream>
 2 using namespace std;
 3 
 4 int foo(int a[], int n, int item)
 5 {
 6     int left = 0, right = n - 1;
 7     int middle = 0;
 8     while (left <= right)
 9     {
10         middle = (left + right) / 2;
11         if (item > a[middle])
12         {
13             left = middle + 1;
14         }
15         else if (item < a[middle])
16         {
17             right = middle - 1;
18         }
19         else
20         {
21             return middle;
22         
23         }
24     }
25     return -1;
26 }
27 
28 int bar(int a[], int n, int item)
29 {
30     int left = 0, right = n - 1;
31     int middle = 0;
32     while (left <= right)
33     {
34         middle = (left + right) / 2;
35         if (item < a[middle])
36         {
37             if (a[left] < item)
38             {
39                 right = middle - 1;
40             }
41             else if (a[left] > item)
42             {
43                 left = middle + 1;
44             }
45             else
46             {
47                 return left;
48             }
49             // right = middle - 1;
50         }
51         else if (item > a[middle])
52         {
53             if (a[right] > item)
54             {
55                 left = middle + 1;
56             }
57             else if (a[right] < item)
58             {
59                 right = middle - 1;
60             }
61             else
62             {
63                 return right;
64             }
65         }
66         else
67         {
68             return middle;
69         }
70     }
71     return -1;
72 }
73 
74 int main()
75 {
76     int a[] = {12345678910};
77     cout << foo(a, sizeof (a) / sizeof (*a), 3<< endl;
78     int b[] = {67891012345};
79     cout << bar(b, sizeof (b) / sizeof (*b), 5<< endl;
80     return 0;
81 }

實現:



posted on 2011-10-29 00:04 unixfy 閱讀(195) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美韩国日本一区| 一区二区三区四区国产| 国产欧美一区二区精品忘忧草 | 久久久中精品2020中文| 亚洲激情在线观看| 欧美在线关看| 欧美日韩视频在线第一区| 国产欧美在线视频| 亚洲欧美国产日韩中文字幕| 亚洲欧洲在线看| 你懂的视频一区二区| 激情综合亚洲| 久久久久久成人| 亚洲一区精彩视频| 国产精品电影在线观看| 亚洲影院在线| 亚洲美女中文字幕| 欧美日韩一区在线观看| 亚洲视频综合| 亚洲精品久久7777| 欧美精品久久99| 亚洲欧洲偷拍精品| 欧美成人综合一区| 亚洲精品欧美日韩专区| 美日韩精品免费| 亚洲国产小视频在线观看| 久久精品视频在线免费观看| 午夜精品一区二区三区在线视 | 久久久综合视频| 在线成人激情黄色| 久久久亚洲欧洲日产国码αv | 午夜免费电影一区在线观看| 亚洲一区日本| 欧美四级剧情无删版影片| 亚洲综合日韩| 一级成人国产| 国产欧美三级| 欧美一区二区视频在线| 欧美亚洲综合久久| 国产一区二区久久| 亚洲第一区在线| 欧美护士18xxxxhd| 国产精品99久久久久久人 | 久热精品在线| 亚洲激情国产精品| 国产美女精品视频| 狂野欧美一区| 久久看片网站| 一区二区三区四区五区精品视频 | 午夜电影亚洲| 亚洲影院高清在线| 久久综合九色欧美综合狠狠| 激情国产一区| 亚洲人妖在线| 欧美午夜精品一区| 久久男人资源视频| 欧美α欧美αv大片| 亚洲一区二三| 欧美一区二区三区四区夜夜大片 | 日韩亚洲欧美高清| 亚洲一区二区日本| 国产亚洲精品美女| 亚洲精品一品区二品区三品区| 欧美精品免费看| 欧美在线视频观看免费网站| 欧美一区二区私人影院日本| 亚洲精品午夜| 亚洲午夜视频在线| 亚洲蜜桃精久久久久久久| 在线亚洲电影| 国产精品网站在线观看| 美国三级日本三级久久99| 欧美国产高清| 欧美一区二区三区在线观看视频| 亚洲精品欧美日韩| 国内精品免费午夜毛片| 亚洲第一精品影视| 国内成+人亚洲| 亚洲精品久久久久久一区二区| 激情成人综合| 亚洲午夜电影网| 中日韩高清电影网| 久久久国产午夜精品| 性欧美激情精品| 欧美成人精品在线视频| 老色鬼精品视频在线观看播放| 欧美视频三区在线播放| 亚洲国产日韩欧美在线图片| 国产欧美精品在线播放| 亚洲欧美日韩在线高清直播| 欧美日韩精品三区| 猛男gaygay欧美视频| 国产亚洲人成a一在线v站| 亚洲欧洲精品一区| 亚洲精品中文字幕有码专区| 欧美有码视频| 久久理论片午夜琪琪电影网| 欧美日韩免费观看中文| 亚洲精品美女在线观看| 欧美午夜a级限制福利片| 欧美精品在线免费观看| 欧美激情国产日韩精品一区18| 国产欧美日韩在线播放| 小黄鸭视频精品导航| 亚洲一品av免费观看| 欧美日韩综合不卡| 亚洲国产一区二区a毛片| 亚洲精品日韩在线观看| 欧美在线影院在线视频| 久久久一区二区| 国产欧美一级| 国产一区在线视频| 欧美一区二区三区啪啪| 欧美成人精品在线| 亚洲经典在线看| 亚洲精品国产精品乱码不99按摩| 欧美成人tv| 欧美成人有码| 亚洲最新色图| 欧美激情综合| 亚洲一区视频在线观看视频| 亚洲一区二区三区午夜| 国产午夜亚洲精品不卡| 亚洲欧美一区二区三区在线| 国一区二区在线观看| 久久亚洲图片| 欧美~级网站不卡| 在线亚洲欧美专区二区| 欧美老女人xx| 亚洲欧美在线视频观看| 久久成人精品视频| 亚洲欧洲精品一区二区精品久久久| 老司机67194精品线观看| 亚洲精品一区二区三区婷婷月| 一区二区三区视频免费在线观看| 国产麻豆综合| 久久视频精品在线| 一级日韩一区在线观看| 久久久91精品国产一区二区三区 | 欧美在线综合| 亚洲精品国产精品久久清纯直播| 亚洲精品一区在线| 国产精品婷婷午夜在线观看| 亚洲免费影视| 午夜精品久久久久久久| 在线播放亚洲| 午夜精品久久久久久久白皮肤| 欧美激情精品久久久久久免费印度| 亚洲黄色高清| 国产伦精品一区二区三区免费 | 91久久久在线| 欧美一级欧美一级在线播放| 亚洲国产精品尤物yw在线观看| 欧美精品一线| 久久―日本道色综合久久| 亚洲欧洲视频在线| 久久综合伊人77777麻豆| 日韩图片一区| 影音先锋亚洲一区| 欧美日韩国产成人在线免费| 久久一区二区三区四区| 一区二区三区欧美亚洲| 亚洲国产精品第一区二区三区| 一区二区三区四区五区精品| 亚洲国产精品999| 欧美午夜精品久久久| 欧美久久久久久蜜桃| 校园春色综合网| 亚洲一区二区三区在线播放| 欧美大香线蕉线伊人久久国产精品| 欧美一区二区三区免费在线看| 亚洲美女av网站| 亚洲人成绝费网站色www| 国产欧美一区二区三区国产幕精品 | 国产精品av一区二区| 久久国产精品亚洲77777| 国产精品99久久久久久白浆小说| 久久久福利视频| 欧美影院午夜播放| 日韩亚洲在线| 日韩一二三在线视频播| 国产一级久久| 国内外成人免费视频| 欧美色精品天天在线观看视频| 欧美国产第一页| 久久久亚洲人| 免费高清在线视频一区·| 欧美在线观看视频一区二区| 欧美一区二区三区视频在线观看 | 国产精品一区2区| 欧美日韩在线一二三| 欧美天天在线| 欧美日韩一区二区免费在线观看| 欧美连裤袜在线视频| 免费成人高清| 欧美视频国产精品| 欧美性色视频在线| 国产欧美日本| 国产欧美日韩精品一区| 禁断一区二区三区在线|