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

那誰的技術(shù)博客

感興趣領(lǐng)域:高性能服務(wù)器編程,存儲(chǔ),算法,Linux內(nèi)核
隨筆 - 210, 文章 - 0, 評(píng)論 - 1183, 引用 - 0
數(shù)據(jù)加載中……

二分查找算法(迭代和遞歸版本)

Bentley在他的著作《Writing Correct Programs》中寫道,90%的計(jì)算機(jī)專家不能在2小時(shí)內(nèi)寫出完全正確的二分搜索算法。
我自己嘗試了一下,確實(shí)要第一次就完全寫正確不容易.以下兩份實(shí)現(xiàn)依次為迭代和遞歸版本的代碼,二分查找的思想很多人都清楚,但是這里有一個(gè)細(xì)節(jié)就是要注意邊界的選擇.


int search(int array[], int n, int v)
{
    
int left, right, middle;

    left 
= 0, right = n - 1;

    
while (left <= right)
    {
        middle 
= (left + right) / 2;
        
if (array[middle] > v)
        {
            right 
= middle - 1;
        }
        
else if (array[middle] < v)
        {
            left 
= middle + 1;
        }
        
else
        {
            
return middle;
        }
    }

    
return -1;
}

int search_recurse(int array[], int low, int high, int v)
{
    
int middle;

    middle 
= (low + high) / 2;

    
if (low < high)
    {
        
if (array[middle] > v)
        {
            
return search_recurse(array, low, middle, v);
        }
        
else if (array[middle] < v)
        {
            
return search_recurse(array, middle + 1, high, v);
        }
        
else
        {
            
return middle;
        }
    }
    
else if (low == high)
    {
        
if (array[middle] == v)
        {
            
return middle;
        }
        
else
        {
            
return -1;
        }

    }
    
else
    {
        
return -1;
    }

    
return -1;
}

int main()
{
    
int array[] = {012345671319};

    
int m = search(array, sizeof(array)/sizeof(array[0]), 13);

    printf(
"m = %d\n", m);

    m 
= search_recurse(array, 0sizeof(array)/sizeof(array[0])13);

    printf(
"m = %d\n", m);

    
return 0;
}


posted on 2009-02-28 19:36 那誰 閱讀(18395) 評(píng)論(15)  編輯 收藏 引用 所屬分類: 算法與數(shù)據(jù)結(jié)構(gòu)

評(píng)論

# re: 二分查找算法(迭代和遞歸版本)  回復(fù)  更多評(píng)論   

二分查找原理簡單,甚至小學(xué)生都能明白。不過這查找算法好多大學(xué)生都寫不好。沒辦法,編程這東西,很討厭。不過,要吃飯呵。
2009-03-01 13:58 |

# re: 二分查找算法(迭代和遞歸版本)  回復(fù)  更多評(píng)論   

應(yīng)該是sizeof(array)/sizeof(array[0])
2009-03-01 14:46 | 阿郎

# re: 二分查找算法(迭代和遞歸版本)  回復(fù)  更多評(píng)論   

其實(shí),上面的代碼還是有問題——兩個(gè)int值相加可能溢出。。。
2009-03-01 22:19 | Joshua Zhu

# re: 二分查找算法(迭代和遞歸版本)  回復(fù)  更多評(píng)論   

middle = (low + high) / 2;
這個(gè)變成 middle = low + ((hight - low) / 2), 在代碼之美里看到的。
其實(shí)這樣也行吧。 middle = low/2 + hight/2 就是慢一點(diǎn)兩次除法運(yùn)算
2009-03-05 19:08 | reeze

# re: 二分查找算法(迭代和遞歸版本)  回復(fù)  更多評(píng)論   

@reeze:
同學(xué),middle = low/2 + hight/2是不對(duì)滴。因?yàn)樗男Ч喈?dāng)于 floor(low / 2) + floor(hight / 2)。
2009-03-07 09:44 | Joshua Zhu

# re: 二分查找算法(迭代和遞歸版本)  回復(fù)  更多評(píng)論   

search_recurse(array, low, middle, v);
這句可以改成
search_recurse(array, low, middle-1, v);
吧?
2009-09-20 23:42 | fzj

# re: 二分查找算法(迭代和遞歸版本)  回復(fù)  更多評(píng)論   

你的迭代法也不對(duì)
2010-09-09 11:15 | 錢文武

# re: 二分查找算法(迭代和遞歸版本)  回復(fù)  更多評(píng)論   

學(xué)習(xí)了
2011-04-14 18:49 | bubble

# re: 二分查找算法(迭代和遞歸版本)  回復(fù)  更多評(píng)論   

這個(gè)實(shí)現(xiàn)有BUG,找不到第一個(gè)和最后一個(gè)數(shù)據(jù),最后不應(yīng)該RETURN -1,應(yīng)該再比較一次
2011-12-08 20:30 | zlc

# re: 二分查找算法(迭代和遞歸版本)  回復(fù)  更多評(píng)論   

把 int search_recurse(int array[], int low, int high, int v)中的
else if (low == high)
{
if (array[middle] == v)
{
return middle;
}
else
{
return -1;
}

}
else
{
return -1;
}
去掉,接著把上面的if (low < high)的if改為while,一樣可以執(zhí)行。

完整代碼:
int search_recurse(char *arr,int value,int n)
{
int min = 0; //設(shè)置最小值為0
int max = n - 1; //設(shè)置最大值為n - 1;
int mid;
int pos = -1; //位置初始化為-1
while(min < max)
{
mid = min + (max - min)/ 2; //將字符串折半
if(arr[mid] > value) //如果中間的值大于要查找的值,則在小的一半中查找
max = mid - 1;
else if(arr[mid] < value) //如果中間的值小于要查找的值,則在大的一半中查找
min = mid + 1;
else //如果找到記錄下位置
{
pos = mid;
max = mid - 1; //再在小的一半中繼續(xù)查找
}
}
if(arr[min] == value) //如果是第一個(gè)字符等于要查找的值,記下位置
pos = min;
return pos; //返回值
}
2012-03-16 21:31 | 莫蕭

# re: 二分查找算法(迭代和遞歸版本)  回復(fù)  更多評(píng)論   

上面的“完整代碼”部分手誤復(fù)制錯(cuò)了。不過這段代碼也是可行的,不是遞歸而已。
本來的完整代碼代碼:

int search_recurse(int arr[], int low, int high, int key)
{
int mid;

mid = (low + high) / 2;
while (low < high)
{
if (arr[mid] > key)
{
return BinSearch(arr, low, mid, key);
}
else if (arr[mid] < key)
{
return BinSearch(arr, mid + 1, high, key);
}
else
{
return mid;
}
}

return -1;
}
2012-03-16 21:34 | 莫蕭

# re: 二分查找算法(迭代和遞歸版本)  回復(fù)  更多評(píng)論   

@zlc
博主在循環(huán)條件中使用的是“<=”,是可以遍歷到第一個(gè)和最后一個(gè)元素的。
2012-10-05 09:57 | 孫磊磊

# re: 二分查找算法(迭代和遞歸版本)  回復(fù)  更多評(píng)論   

測(cè)試環(huán)境:vs2005+XP
// test.cpp : 定義控制臺(tái)應(yīng)用程序的入口點(diǎn)。
//
#include "stdafx.h"
#include <conio.h>
#include <cstdlib>
#include <stdlib.h>
#include <iostream>
#include <bitset> //為了能夠用std::bitset
#include <limits>

#include <time.h>
using namespace std;


#include<assert.h>

//二分查找算法,前提是這個(gè)數(shù)組要是排好序的!
//先假設(shè)是int數(shù)組,返回值表示數(shù)組的下標(biāo)。
//(1)迭代算法
int gezb_bsearch(int Source[], int Len, int Key)
{
int low=0,high=Len-1;
while(low<=high)
{
std::cout<<"low["<<low<<"]="<<Source[low]<<",high["<<high<<"]="<<Source[high]<<std::endl;
//if (Key<Source[low] || Key>Source[high])
//{
// std::cout<<"can't find ! key="<<Key<<",low["<<low<<"]="<<Source[low]<<",high["<<high<<"]="<<Source[high]<<std::endl;
// break;
//}
int middle = (low + high)/2;
if (Key==Source[middle])
{
std::cout<<"ok get it. \ncurIndex="<<middle<<", key="<<Key<<std::endl;
return middle;
}
else if (Key>Source[middle])
{
low = middle+1;
}
else if (Key<Source[middle])
{
high = middle-1;
}
}
return -1;
}

//(2)遞歸算法
int gezb_bsearch_recurse(int Source[],int Low,int High,int Key)
{
int middle;
if (Low<=High)
{
std::cout<<"low["<<Low<<"]="<<Source[Low]<<",high["<<High<<"]="<<Source[High]<<std::endl;
middle = (Low+High)/2;
if (Source[middle]==Key)
{
std::cout<<"ok get it. \ncurIndex="<<middle<<", key="<<Key<<std::endl;
return middle;
}
else if (Source[middle]>Key)
{
return gezb_bsearch_recurse(Source,Low,middle-1,Key);
}
else if (Source[middle]<Key)
{
return gezb_bsearch_recurse(Source,middle+1,High,Key);
}
}
return -1;
}


#define MAXLEN 10000
void main(void)
{
int arr[MAXLEN];
memset(arr,0,sizeof(arr));
for (int i=0;i<MAXLEN;++i)
{
arr[i]=(i+1)*2;
}
int key=arr[7777];
int iLen = sizeof(arr) / sizeof(arr[0]);

#if 0
//迭代算法
int index = gezb_bsearch(arr,iLen-1,key);
std::cout<<index<<std::endl;
#endif

#if 1
//遞歸算法
int index = gezb_bsearch_recurse(arr,0,iLen-1,key);
std::cout<<index<<std::endl;
#endif

system("PAUSE");
}

2013-03-31 01:18 | gezb

# re: 二分查找算法(迭代和遞歸版本)  回復(fù)  更多評(píng)論   

有問題請(qǐng)與我聯(lián)系。qq:275916517
2013-03-31 01:20 | gezb

# re: 二分查找算法(迭代和遞歸版本)  回復(fù)  更多評(píng)論   

針對(duì)迭代算法的調(diào)用處稍做修改:
#if 0
//迭代算法
int index = gezb_bsearch(arr,iLen,key);//之前iLen-1是錯(cuò)誤的!!!
std::cout<<index<<std::endl;
#endif
2013-03-31 02:05 | gezb
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久久久久国产精品mv| 欧美久久久久免费| 午夜激情久久久| 亚洲精品日韩激情在线电影| 99国产精品久久久久久久久久| 欧美激情一二区| 亚洲精品一区在线观看香蕉| 一二三四社区欧美黄| 亚洲一区中文字幕在线观看| 性欧美超级视频| 久久综合成人精品亚洲另类欧美| 久久久久久久一区二区| 欧美喷潮久久久xxxxx| 国产精品h在线观看| 国产在线欧美日韩| 亚洲狠狠婷婷| 校园激情久久| 欧美大片在线看| 亚洲无亚洲人成网站77777| 久久久国产一区二区| 欧美成人精品h版在线观看| 欧美色另类天堂2015| 韩日成人av| 亚洲一区免费视频| 欧美国产在线电影| 亚洲欧美卡通另类91av| 女人香蕉久久**毛片精品| 国产欧美一区二区三区沐欲 | 99re视频这里只有精品| 午夜久久美女| 91久久精品日日躁夜夜躁国产| 亚洲国产1区| 欧美在线视频免费观看| 欧美视频国产精品| 亚洲日韩欧美视频一区| 久久久99爱| 亚洲影院色无极综合| 欧美日韩国产一区二区三区地区 | 99国产精品99久久久久久| 久久精品国亚洲| 亚洲视屏在线播放| 欧美日韩另类视频| 亚洲九九爱视频| 欧美成人精品一区| 欧美一区二区观看视频| 国产精品毛片大码女人| 亚洲字幕在线观看| 亚洲乱码国产乱码精品精| 欧美成人黑人xx视频免费观看| 国内精品久久久久伊人av| 欧美一区2区视频在线观看| 一区二区91| 欧美视频中文在线看| 日韩午夜激情电影| 亚洲精品日韩欧美| 欧美日韩另类视频| 欧美日韩亚洲天堂| 一本色道久久综合亚洲精品婷婷 | 国产亚洲毛片在线| 欧美一区日本一区韩国一区| 亚洲在线1234| 国产精品网站在线| 先锋影音久久久| 亚洲男同1069视频| 国产欧美日韩精品在线| 久久久精品久久久久| 欧美在线视频二区| 精品1区2区3区4区| 亚洲高清在线视频| 欧美日韩另类视频| 午夜综合激情| 久久国产日韩| 91久久精品国产91久久性色| 亚洲国产日韩一区二区| 欧美日韩精选| 久久精品成人一区二区三区蜜臀 | 一区二区三区免费网站| 欧美日韩一区二区三区高清| 99热免费精品| 亚洲视频第一页| 国产欧美一区二区色老头| 久久亚洲综合网| 欧美精品福利| 欧美在线免费看| 久久偷窥视频| 亚洲免费观看在线观看| 国产精品99久久久久久人| 国产精品永久免费在线| 免费日韩视频| 欧美日韩亚洲一区在线观看| 久久www免费人成看片高清| 久久久久久久久久久一区| 亚洲全部视频| 午夜免费久久久久| 亚洲日韩成人| 欧美亚洲在线| 9色精品在线| 久久超碰97中文字幕| 夜色激情一区二区| 久久精品二区| 亚洲欧美日韩国产综合在线| 久久久欧美一区二区| 亚洲伊人伊色伊影伊综合网| 久久人人爽人人爽| 欧美在线国产| 欧美日韩免费一区二区三区视频| 久久久久国产精品一区二区| 欧美日韩亚洲成人| 欧美丰满高潮xxxx喷水动漫| 国产精品日韩电影| 亚洲精华国产欧美| 在线播放日韩欧美| 午夜视频在线观看一区二区三区 | 午夜在线a亚洲v天堂网2018| 日韩午夜激情av| 久久免费精品视频| 欧美一区激情| 国产精品久久久久毛片软件| 亚洲人久久久| 亚洲黄色天堂| 久久久999成人| 久久不见久久见免费视频1| 欧美日韩一区二区三区免费看| 欧美成人在线免费观看| 国产日产高清欧美一区二区三区| 99这里有精品| 一区二区三区日韩精品| 欧美国产免费| 亚洲国产一区二区三区在线播| 伊人久久婷婷色综合98网| 羞羞答答国产精品www一本| 香蕉成人久久| 国产欧美日韩综合精品二区| 亚洲欧美日韩精品久久| 欧美一级理论性理论a| 国产精品美女久久久免费| 亚洲一级二级在线| 欧美亚洲在线视频| 国产综合色产在线精品| 久久国产婷婷国产香蕉| 久久美女性网| 在线精品观看| 欧美激情91| 中文无字幕一区二区三区| 午夜激情久久久| 精品电影一区| 免费不卡在线观看| 亚洲国产成人久久综合一区| 日韩一级在线观看| 国产精品vip| 午夜视频在线观看一区| 蜜桃久久精品乱码一区二区| 亚洲欧洲日产国产综合网| 欧美日韩国产色综合一二三四| 亚洲最快最全在线视频| 久久国产精品一区二区三区四区| 国内久久精品| 欧美国产在线电影| 亚洲美女中出| 久久国产精彩视频| 亚洲国产婷婷香蕉久久久久久| 欧美伦理视频网站| 亚洲一区国产视频| 六十路精品视频| 亚洲图片在线观看| 国产欧美日韩亚洲精品| 久久手机免费观看| 99精品欧美一区二区三区| 久久精品伊人| 亚洲免费黄色| 国产午夜精品一区二区三区视频 | 国产情人综合久久777777| 久久久久久尹人网香蕉| 亚洲美女色禁图| 久久久久综合一区二区三区| 日韩一级网站| 黄网站色欧美视频| 欧美视频第二页| 亚洲国产日韩一区二区| 亚洲女人天堂成人av在线| 激情偷拍久久| 欧美视频在线一区二区三区| 久久综合色影院| 午夜视频一区在线观看| 亚洲黄色精品| 久久精品在线观看| 亚洲调教视频在线观看| 亚洲国产精品第一区二区三区| 国产精品人成在线观看免费 | 玖玖综合伊人| 午夜久久久久久| 在线亚洲激情| 亚洲精品系列| 在线观看亚洲a| 国产精品无码永久免费888| 欧美日本二区| 免费成年人欧美视频| 久久久久91| 欧美永久精品| 欧美亚洲综合网|