日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪(fǎng)問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

折半查找算法及分析(手工过程)

發(fā)布時(shí)間:2023/12/1 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 折半查找算法及分析(手工过程) 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

折半查找的手工過(guò)程:

1.我需要查找的數(shù)是10;

給定:1? 5? 8? 10? 13 14? 17? 22? 25? 27? 29? 31? 35? 37? 40? 42? 45? 47? 50? 51? 58

下標(biāo):0? 1? 2?? 3 ? 4 ?? 5 ?? 6 ?? 7 ? ? 8 ?? 9?? 10? 11? 12? 13? 14? 15? 16? 17? 18? 19? 20

   h               m                  t

   h    m        ? t

   h m  t

     h ? t

     m? h

      ?m

這個(gè)手工過(guò)程到head = tail 時(shí)找到了。

我需要查找的數(shù)是29;

給定:1? 5? 8? 10? 13 14? 17? 22? 25? 27? 29? 31? 35? 37? 40? 42? 45? 47? 50? 51? 58

下標(biāo):0? 1? 2?? 3 ? 4 ?? 5 ?? 6 ?? 7 ? ? 8 ?? 9?? 10? 11? 12? 13? 14? 15? 16? 17? 18? 19? 20

   h               m                  t

這個(gè)手工過(guò)程數(shù)在head < tail時(shí)程序停止,找到的是下標(biāo)的那個(gè)數(shù)。

代碼如下:

#include<stdio.h> #include<stdlib.h> int binarySearch(int *arr,int count ,int data){int middle;int head = 0;int tail;tail = count;while(arr[middle] != data){middle = (head + tail)/ 2;if(arr[middle] < data){head = middle + 1;}else if(arr[middle] > data){tail = middle - 1;}} return middle;return -1; } int main(){int n = 0;int m ;int a[10]={1,4,8,9,16,17,19,20,25,27};printf("請(qǐng)輸入需要查找的數(shù): ");scanf("%d",&n);m = binarySearch(a,10,n);printf("%d ",m);return 0; }

這是一個(gè)簡(jiǎn)單的折半處理,用的是一個(gè)簡(jiǎn)單的數(shù)組

需要強(qiáng)調(diào)的是:

      如果要運(yùn)用折半算法,數(shù)必須是有序的(升序或者降序)

      很多人都認(rèn)為while(head > tail)這樣也是正確的,但是對(duì)于middle = data時(shí)條件一直成立就會(huì)出現(xiàn)問(wèn)題的!

轉(zhuǎn)載于:https://www.cnblogs.com/youdiaodaxue16/p/9016337.html

總結(jié)

以上是生活随笔為你收集整理的折半查找算法及分析(手工过程)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。