冒泡排序和二分查找

简介:

js的排序

我们这里只介绍一下冒泡排序法:[其它方法可以参考 php 的排序章节]

 

 

代码:

<html>

<head>

<meta http-equiv="content-type" content="text/html;charset=utf-8"/>

 

<script type="text/javascript">

 

var arr=[0,-1,90,-18,900,90,78];

 

var temp=0;

for(var i=0;i<arr.length-1;i++)

{

   //定小循环

   for(var j=0;j<arr.length-1-i;j++){

      

       if(arr[j]>arr[j+1]){

         //交换

         temp=arr[j];

         arr[j]=arr[j+1];

         arr[j+1]=temp;

       }

   }

 

     

}

 

//输出数组 

   document.write(arr);

 

</script>

</html>

js的查找

顺序查找

一个一个的比较,如果是则查找到.

 

var arr=[3,5,90,12,-23];

 

var findVal=90;

var flag=false;

for(var i=0;i<arr.length;i++){

 if(arr[i]= = findVal){

document.write(”找到了这个数 下标是”+i);

flag=true;

}

}

 

if(!flag){

document.write(”一个都没有找到”);

}

 

二分查找

面试题一定掌握!

 

//二分查找[递归]

 

//二分查找要保证我们的数组是一个有序的.

//思想是

//首先把数组的中间这个数找出,然后和你要查询的数比较

//① 你要查询的数比中间的数大则说明我们应当该数组的右边[后边]查询

//② 你要查询的数比中间的数小 .则说明我们应当该数组的左边[前边]查询

//③ 你要查询的数等于中间的数说明找到  

 

var arr=[1,90,100,123,4000];

 

function binarySearch(findVal,arr,leftIndex,rightIndex){

 

//退出条件

if(rightIndex<leftIndex){

document.write("查询没有结果");

return;

}

 

//代码:

//找到中间数的下标

var midIndex=Math.round((leftIndex+rightIndex)/2);

 

if(arr[midIndex]<findVal){

binarySearch(findVal,arr,midIndex+1,rightIndex);

}else if(arr[midIndex]>findVal){

    binarySearch(findVal,arr,leftIndex,midIndex-1);

}else{

document.write("找到 下标是"+midIndex);

//binarySearch(findVal,arr,leftIndex,midIndex-1);

}

 

}

 

//调用的格式

binarySearch(100,arr,0,arr.length-1);

目录
相关文章
|
4月前
|
搜索推荐 算法
冒泡排序的时间复杂度是多少?
【2月更文挑战第8天】【2月更文挑战第22篇】冒泡排序的时间复杂度是多少?
87 1
|
3月前
|
算法 数据处理 Python
插入排序、选择排序和二分查找
插入排序、选择排序和二分查找
|
3月前
|
搜索推荐
冒泡排序、选择排序、二分查找
冒泡排序、选择排序、二分查找
10 0
|
存储 搜索推荐 算法
八大排序算法-直接插入排序、希尔排序、直接选择排序、冒泡排序、堆排序、快速排序、归并排序、基数排序(下)
八大排序算法-直接插入排序、希尔排序、直接选择排序、冒泡排序、堆排序、快速排序、归并排序、基数排序(下)
【交换排序】冒泡排序 与 快速排序
【交换排序】冒泡排序 与 快速排序
|
算法 搜索推荐
简单选择排序,直接插入排序、冒泡排序
简单选择排序,直接插入排序、冒泡排序
|
算法 搜索推荐 C语言
|
算法
交换排序 (冒泡排序 && 快速排序)
交换排序 (冒泡排序 && 快速排序)
90 0
交换排序 (冒泡排序 && 快速排序)