JavaScrip常见的一些算法总结
作者:bea
下面就简单列举一下javascript中常见的一些算法,需要的朋友可以做一下参考。当然这些算法不仅仅适用于javascript,同样也适用于其他语言。 一.线性查找: 比较简单,属于入门级的算法 //A为数组,x为要搜索的值function linearSearch(A, x) {for (var index = 0; index < A.length; index++) {if (A[index] == x) {return index;}}return -1;}
下面就简单列举一下javascript中常见的一些算法,需要的朋友可以做一下参考。当然这些算法不仅仅适用于javascript,同样也适用于其他语言。
一.线性查找:
比较简单,属于入门级的算法
//A为数组,x为要搜索的值
function linearSearch(A, x) {
for (var index = 0; index < A.length; index++) {
if (A[index] == x) {
return index;
}
}
return -1;
}
二.二分查找:
又称折半查找,适用于已排好序的线性结构。
//A为已按"升序排列"的数组,x为要查询的元素
//返回目标元素的下标
function binarySearch(A, x) {
var low = 0, high = A.length - 1;
while (low <= high) {
var mid = Math.floor((low + high) / 2); //下取整
if (x == A[mid]) {
return mid;
}
if (x < A[mid]) {
high = mid - 1;
}
else {
low = mid + 1;
}
}
return -1;
}
三.冒泡排序:
//冒泡排序
function bubbleSort(A) {
for (var i = 0; i < A.length; i++) {
var sorted = true;
//注意:内循环是倒着来的
for (var j = A.length - 1; j > i; j--) {
if (A[j] < A[j - 1]) {
swap(A, j, j - 1);
sorted = false;
}
}
if (sorted) {
return;
}
}
}
四.插入排序:
//插入排序
//假定当前元素之前的元素已经排好序,先把自己的位置空出来,
//然后前面比自己大的元素依次向后移,直到空出一个"坑",
//然后把目标元素插入"坑"中
function insertSort(A) {
for (var index= 1; index< A.length; index++) {
var x = A[index];
for (var j = index- 1; j >= 0 && A[j] > x; j--) {
A[j + 1] = A[j];
}
if (A[j + 1] != x) {
A[j + 1] = x;
println(A);
}
}
return A;
}
五.字符串反转:
//字符串反转(比如:ABC -> CBA)
function inverse(s) {
var arr = s.split(');
var index= 0, j = arr.length - 1;
while (index< j) {
var t = arr[index];
arr[index] = arr[j];
arr[j] = t;
index++;
j--;
}
return arr.join(');
}
以上内容给大家简单介绍了JavaScrip常见的算法总结,希望本文能够给大家带来帮助。
猜你喜欢
您可能感兴趣的文章:
- Jsonp 关键字详解及json和jsonp的区别,ajax和jsonp的区别
- javascript实现禁止复制网页内容汇总
- jquery实现树形菜单完整代码
- javascript设置页面背景色及背景图片的方法
- js获取及修改网页背景色和字体色的方法
- 基于JavaScript实现根据手机定位获取当前具体位置(X省X市X县X街道X号)
- jQuery中attr()与prop()函数用法实例详解(附用法区别)
- 使用OpenLayers3 添加地图鼠标右键菜单
- javascript实现下拉提示选择框
- 基于JavaScript如何实现ajax调用后台定义的方法
- js+css简单实现网页换肤效果
- Jquery使用小技巧汇总
- js为什么不能正确处理小数运算?
- javascript从作用域链谈闭包
- 你有必要知道的25个JavaScript面试题
- JavaScript仿支付宝密码输入框
- js实现商城星星评分的效果
- 原生js配合cookie制作保存路径的拖拽
- 一种新的javascript对象创建方式Object.create()