国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

javascript中"/"運算符常見錯誤

2019-11-21 00:12:29
字體:
來源:轉載
供稿:網友
//二分查找健忘遞歸版本
復制代碼 代碼如下:

function binary_search(arr,target,low,high){
if(low<high){ //至少包括兩個元素
          var min=(low+high)/2;
if(target>arr[min])
return binary_search(arr,target,min+1,high);
else
return binary_search(arr,target,low,min);
}else if(low==high){ //只剩下一個元素
if(arr[low]==target)
return low;
else return -1;
}else if(low>high){ //空,當用arr.length-1來計算arr的初始high時才要考慮
return -1;
}
}

var arr=[1,2,3,4,5,6];
alert(binary_search(arr,3,0,arr.length-1));
晚上看數據結構,順便就用js寫了個二分查找算法(代碼如上),然后隨便寫了個數組作為測試數據(如上),按照設想應該是輸出查找目標的下標,但是意向不到的事情發生了,只見CPU霎時狂轉,約兩秒后,瀏覽器自動終止了腳本的運行,然后就一陣納悶。

根據經驗來看,應該是在腳本運行的過程出現了死循環,自習看了一下算法,沒有發現什么問題(干脆直接照著課本上的代碼輸入總不會錯了吧),但是問題依舊。于是就在第一個判斷條件里面加了個輸出語句,如下:
復制代碼 代碼如下:

//二分查找健忘遞歸版本function binary_search(arr,target,low,high){
if(low<high){ //至少包括兩個元素          
  var min=(low+high)/2;
       if(target>arr[min])
return binary_search(arr,target,min+1,high);
  else
    return binary_search(arr,target,low,min);
}else if(low==high){ //只剩下一個元素
  if(arr[low]==target)
    return low;
   else return -1;
}else if(low>high){ //空,當用arr.length-1來計算arr的初始high時才要考慮
  return -1;
}
}

運行,彈出個對話框,里面數字為2.5~~突然有種恍然大悟同時想要砸電腦的沖動。

出錯原因以及總結:
  javascript里面的"/"運算符跟C++里面的"/"運算符不一樣,后者自動取整,前者若非整除則會得到小數(比如說5/2=2.5)。
解決方案:

(1)var min=parseInt((low+high)/2);
(2)var min=Match.floor((low+high)/2);
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 温州市| 翼城县| 潜江市| 顺平县| 鄂尔多斯市| 沅陵县| 蕉岭县| 南部县| 神池县| 庆阳市| 石渠县| 枣阳市| 龙州县| 克东县| 长子县| 宣化县| 广昌县| 高邑县| 孟津县| 石阡县| 鹿泉市| 沂南县| 曲周县| 资源县| 正宁县| 军事| 德惠市| 崇左市| 玉山县| 华阴市| 健康| 宾阳县| 靖西县| 五华县| 凤城市| 荃湾区| 青岛市| 东源县| 江达县| 迁西县| 沧州市|