javascript数据结构与算法之检索算法


Posted in Javascript onApril 04, 2015

查找数据有2种方式,顺序查找和二分查找。顺序查找适用于元素随机排列的列表。二分查找适用于元素已排序的列表。二分查找效率更高,但是必须是已经排好序的列表元素集合。

一:顺序查找
顺序查找是从列表的第一个元素开始对列表元素逐个进行判断,直到找到了想要的结果,或者直到列表的结尾都没有找到想要找的元素。

代码如下:

function seqSearch(data,arr) {
  for(var i = 0; i < arr.length; ++i) {
    if(arr[i] == data) {
      return true;
    }
  }
  return false;
}

我们也可以返回匹配元素位置的顺序查找函数,代码如下:

function seqSearch(data,arr) {
  for(var i = 0; i < arr.length; ++i) {
    if(arr[i] == data) {
      return i;
    }
  }
  return -1;
}

二:查找最小值和最大值

在数组中查找最小值算法如下:

   1. 将数组第一个元素赋值给一个变量,把这个变量作为最小值。
   2. 开始遍历数组,从第二个元素依次同当前最小值进行比较。
   3. 如果当前元素的数值小于当前最小值,则将当前元素设为新的最小值。
   4. 移动到下一个元素,重复步骤3.
   5.  当程序结束时,这个变量中存储的就是最小值。

代码如下:

function findMin(arr) {
  var min = arr[0];
  for(var i = 1; i < arr.length; ++i) {
    if(arr[i] < min) {
      min = arr[i];
    }
  }
  return min;
}

查找最大值算法和上面最小值类似,先将数组中第一个元素设为最大值,然后循环对数组剩余的每个元素与当前最大值进行比较,如果当前元素的值大于当前的最大值,则将该元素的值赋值给最大值。代码如下:

function findMax(arr) {
  var max = arr[0];
  for(var i = 1; i < arr.length; ++i) {
    if(arr[i] > max) {
      max = arr[i];
    }
  }
  return max;
 }

三:二分查找法。

 如果你要查找的数据是有序的,二分查找算法比顺序查找算法效率更高。二分查找算法基本原理如下:

 1. 将数组的第一个位置设置为下边界(0).
 2. 将数组的最后一个元素所在的位置设置为上边界(数组的长度减1)。
 3. 若下边界等于或小于上边界,则做如下操作:
    A. 将中点设置为(上边界加上下边界) 除以2.
    B. 如果中点的元素小于查询的值,则将下边界设置为中点元素所在下标加1.
    C. 如果中点的元素大于查询的值,则将上边界设置为中点元素所在下标减1.
    D. 否则中点元素即为要查找 的数据,可以进行返回。

代码如下:

// 二分查找算法
function binSearch(data,arr) {
var lowerBound = 0;
  var upperBound = arr.length - 1;
  while(lowerBound <= upperBound) {
    var mid = Math.floor((upperBound + lowerBound)/2);
    if(arr[mid] < data) {
      lowerBound = mid + 1;
    }else if(arr[mid] > data) {
      upperBound = mid - 1;
    }else {
      return mid;
    }
  }
  return -1;
}
 // 快速排序
function qSort(list) {
  if(list.length == 0) {
    return [];
  }
  // 存储小于基准值的值
  var left = [];
  // 存储大于基准值的值
  var right = [];
  var pivot = list[0];
  for(var i = 1; i < list.length; i++) {
    if(list[i] < pivot) {
      left.push(list[i]);
    }else {
      right.push(list[i])
    }
  }
  return qSort(left).concat(pivot,qSort(right));
}
 // 测试代码
var numbers = [0,9,1,8,7,6,2,3,5,4];
var list = qSort(numbers);
console.log(binSearch(6,list));

四:计算重复次数;
当二分查找算法binSearch()函数找到某个值时,如果在数据集中还有其他相同的值出现,那么该函数会定位在类似值附近,换句话说,其他相同的值可能会出现已找到值的左边或者右边。

那么我们最简单的方案是写2个循环,一个同时对数据集向下遍历或者向左遍历,统计重复次数;然后,向上或向右遍历,统计重复次数。代码如下:

// 计算重复次数
function count(data,arr) {
  var count = 0;
  var arrs = [];
  var position = binSearch(data,arr);
  if(position > -1) {
    ++count;
    arrs.push({"index":count});
    for(var i = position -1; i > 0; --i) {
      if(arr[i] == data) {
        ++count;
        arrs.push({"index":count});
      }else {
        break;
      }
    }
    for(var i = position + 1; i < arr.length; ++i) {
      if(arr[i] == data) {
        ++count;
        arrs.push({"index":count});
      }else {
        break;
      }
    }
  }
  return arrs;
}
 // 测试重复次数的代码
var arr = [0,1,1,1,2,3,4,5,6,7,8,9];
var arrs = count(1,arr);
console.log(arrs);
console.log(arrs.length);

如下图所示:

javascript数据结构与算法之检索算法

Javascript 相关文章推荐
硬盘浏览程序,保存成网页格式便可使用
Dec 03 Javascript
Javascript技巧之不要用for in语句对数组进行遍历
Oct 20 Javascript
网易JS面试题与Javascript词法作用域说明
Nov 09 Javascript
很棒的学习jQuery的12个网站推荐
Apr 28 Javascript
jQuery中after的两种用法实例
Jul 03 Javascript
JQuery弹出炫丽对话框的同时让背景变灰色
May 22 Javascript
jQuery中:visible选择器用法实例
Dec 30 Javascript
JavaScript登录记住密码操作(超简单代码)
Mar 22 Javascript
fullPage.js和CSS3实现全屏滚动效果
May 05 Javascript
JS对象与json字符串相互转换实现方法示例
Jun 14 Javascript
详解从vue-loader源码分析CSS Scoped的实现
Sep 23 Javascript
Vue实现点击箭头上下移动效果
Jun 11 Javascript
使用jquery制作弹出框效果
Apr 03 #Javascript
javascript 实现map集合
Apr 03 #Javascript
jQuery制作简洁的图片轮播效果
Apr 03 #Javascript
jQuery制作效果超棒的手风琴折叠菜单
Apr 03 #Javascript
jQuery实现左右切换焦点图
Apr 03 #Javascript
基于jquery ui的alert,confirm方案(支持换肤)
Apr 03 #Javascript
javascript制作sql转换为stringBuffer的小工具
Apr 03 #Javascript
You might like
十天学会php之第五天
2006/10/09 PHP
PHP的PSR规范中文版
2013/09/28 PHP
php脚本守护进程原理与实现方法详解
2017/07/20 PHP
PHP基于自定义类随机生成姓名的方法示例
2017/08/05 PHP
javascript eval和JSON之间的联系
2009/12/31 Javascript
很棒的学习jQuery的12个网站推荐
2011/04/28 Javascript
php实例分享之实现显示网站运行时间
2014/05/20 Javascript
Bootstrap3制作图片轮播效果
2016/05/12 Javascript
js轮播图代码分享
2016/07/14 Javascript
angularjs 缓存的使用详解
2018/03/19 Javascript
微信小程序实现上传图片功能
2018/05/28 Javascript
react-native动态切换tab组件的方法
2018/07/07 Javascript
d3.js 地铁轨道交通项目实战
2019/11/27 Javascript
python两种遍历字典(dict)的方法比较
2014/05/29 Python
python实现telnet客户端的方法
2015/04/15 Python
django创建自定义模板处理器的实例详解
2017/08/14 Python
Python GUI编程完整示例
2019/04/04 Python
关于Python字符串显示u...的解决方式
2020/03/06 Python
python3.8动态人脸识别的实现示例
2020/09/21 Python
使用HTML5 Geolocation实现一个距离追踪器
2018/04/09 HTML / CSS
世界上最全面的草药补充剂和顶级品牌维生素网站:HerbsPro
2019/01/20 全球购物
英国最大的滑板品牌选择:Route One
2019/09/22 全球购物
全球领先的中国制造商品在线批发平台:DHgate
2020/01/28 全球购物
Spotahome意大利:公寓和房间出租
2020/02/21 全球购物
What's the difference between an interface and abstract class? (接口与抽象类有什么区别)
2012/10/29 面试题
银行实习生的自我评价
2013/12/09 职场文书
幼儿园义卖活动方案
2014/01/17 职场文书
应届毕业生如何写求职信
2014/02/16 职场文书
活动总结报告范文
2014/05/04 职场文书
应届生求职信范文
2014/06/30 职场文书
学前教育专业求职信
2014/09/02 职场文书
2014党员自我评议表范文
2014/09/20 职场文书
房屋租赁协议书
2014/10/18 职场文书
详解MySQL集群搭建
2021/05/26 MySQL
GitHub上77.9K的Axios项目有哪些值得借鉴的地方详析
2021/06/15 Javascript
Java中API的使用方法详情
2022/04/06 Java/Android