编辑器:Sublime Text 3

1、冒泡排序

let arr = new Array(5,9,3,6,7,8,4,2,);
bubbleSort(arr);
console.log(arr);
function bubbleSort(array){
 //外层循环负责冒泡的次数
 for (let i = 0;  i < (array.length); i++){
  //内层循环单词冒泡的过程
  for (let j = 0; j <(array.length) - 1 - i; j++){ 
   //核心算法 两两比较交换
   if (array[j] > array[j + 1]){
    let temp = array[j];
    array[j] = array[j + 1];
    array[j + 1 ] = temp;
   }
  }
 }
}

返回值:[ 2, 3, 4, 5, 6, 7, 8, 9 ]

2、比较最小值

let arr = new Array(5,9,3,6,7,8,4,2,);
let min = 100;
for (let i = 0; i < arr.length; i++){
 if (min > arr[i]){
  min = arr[i];
 }
}
console.log(min);

返回值:2

3、比较那个位置的值最小值且最小值是多少

let arr = new Array(5,9,3,6,7,8,4,2,);
let minIndex = 0;
let min = 100;
for (let i = 0; i < arr.length; i++){
 if (arr[minIndex] > arr[i]){
  minIndex = i;
 }
}
console.log(minIndex,arr[minIndex]);
 
返回值:7 2
 
注:数组从零开始算
 
3、比较最小值是多少 并放在最左边
let arr = new Array(5,9,3,6,7,8,4,2,);
let i = 0; //代表无序区第一个元素的位置
let minIndex =i;//假定无序区第一个位置是最小的位置
//查找最小值的位置
for (let j = minIndex + 1; j < arr.length; j++){
 if (arr[minIndex] > arr[j]){
  minIndex = j;
 }
}
let temp = arr[i];
arr[i] = arr[minIndex];
arr[minIndex] = temp;
console.log(arr);
//外循环 i 确定无序区的起始位置
for (let i = 0; i < arr.length - 1; i ++){
 //假定无序区的第一个元素就最小的
 let minIndex= i;
 //在当前无序区查找最小值的位置
 for (let j = minIndex + 1; j < arr.length; j++){
  if (arr[minIndex] > arr[j]){
   minIndex = j;
  }
 }
 //找打最下值的位置后跟当前无序区第一个元素交换,进入有序区
 let temp = arr[i];
 arr[i] = arr[minIndex];
 arr[minIndex] = temp;
}
返回值:[ 2, 9, 3, 6, 7, 8, 4, 5 ]
 
4、插入排序
let arr = new Array(5,9,3,6,7,8,1,4,2,);
inserSort(arr);
console.log(arr);
function inserSort(array){
 //外循环确定当前要向前插入元素的位置
 for (let i = 1;i <array.length; i++){
  let j = i;
  //把当前要向前插入的元素保存在 remp 中
  let temp = array[j];
  while (j >0 && temp < array[j - 1]){  //如果要插入的值小于坑前面(j -  1)的元素 后
   array[j] = array[j - 1];  //向后定这个元素
   j--;   //向前移动坑(j)
  }
  //循环结束,找到要插入的位置
  array[j] = temp;
 }
}
返回值:[ 1, 2, 3, 4, 5, 6, 7, 8, 9 ]
 
5、宽容排序
 let arr = new Array(5,9,3,6,7,8,1,4,2,);
insertSort(arr);
console.log(arr);
function insertSort(array){
 //外循环确定当前要向前插入元素的位置
 for (let i = 1;i <array.length; i++){
  let j = i;
  //把当前要向前插入的元素保存在 remp 中
  let temp = array[j];
  while (j >0 && temp < array[j - 1]){  //如果要插入的值小于坑前面(j -  1)的元素 后
   array[j] = array[j - 1];  //向后定这个元素
   j--;   //向前移动坑(j)
  }
  //循环结束,找到要插入的位置
  array[j] = temp;
 }
}
function quickSort(array,left,right){
 if(left >= right){
  return;
 }
 let j = left;
 //以最后位置(right)为基准值
 for (let i = left, j = left;i < right; i++){
  if (array[i] < array[right]){
   let temp =array[i];
   array[i] = array[j];
   array[j] =temp;
   j++;
  }
 }
 let temp = array[j];
 array[j] = array[right];
 array[right] = temp;
 quickSort(array,left,j - 1);
 quickSort(array,j + 1,right);
}
function halfSeek(array,target){
 let left = 0;
 let right = array.length - 1;
 while (left <= right){
  let mid = Math.floor((left + right) / 2);
  if(target > array[mid]){
   left = mid + 1;
  }else if (target < array[mid]){
   right = mid - 1;
  }else {
   return mid;
  }
 }
 return null;
}
返回值:[ 1, 2, 3, 4, 5, 6, 7, 8, 9 ]
 
新手 如有问题欢迎评论 谢谢!

利用 js 的一些函数调用,排序的更多相关文章

  1. 使用 js 实现十大排序算法: 堆排序

    使用 js 实现十大排序算法: 堆排序 堆排序(Heapsort)是指利用堆这种数据结构所设计的一种排序算法. 大顶堆:每个节点的值都大于或等于其子节点的值,在堆排序算法中用于升序排列: 小顶堆:每个 ...

  2. 利用JS脚本通过getAttribute()和setAttribute()等对CSS样式进行操作

    HTML中引入CSS样式的方式有三种: 1.最常用的,引入样式表,在样式表中编写样式,引入方式如下:<link href="css/style.css" rel=" ...

  3. 利用脚本修改SQL SERVER排序规则

    利用脚本修改SQL SERVER排序规则 编写人:CC阿爸 2014-3-1 l  今年的一项重要工作是对公司所用系统进行繁简的转换,程序转成简体基本很容易解决,但数据库转换成简体,就没那么容易了.经 ...

  4. JS 数据类型转换-转换函数、强制类型转换、利用js变量弱类型转换

    1. 转换函数: js提供了parseInt()和parseFloat()两个转换函数.前者把值转换成整数,后者把值转换成浮点数.只有对String类型调用这些方法,这两个函数才能正确运行:对其他类型 ...

  5. 利用js制作html table分页示例(js实现分页)

    有时候table的列数太长,不利于使用者查询,所以利用JS做了一个table的分页,以下为相关代码 一.JS代码 <script type="text/javascript" ...

  6. 利用JS实现闪烁字体

    以下为在JSP文件中,利用JS实现闪烁字体的代码: HTML代码: <div id="blink">一段会闪烁的字</div> JavaScript代码: ...

  7. 利用JS实现HTML TABLE的分页

    有时候table的列数太长,不利于使用者查询,所以利用JS做了一个table的分页,以下为相关代码 一.JS代码 <script type="text/javascript" ...

  8. 利用js闭包获取索引号

    以tab选项卡效果为例: 网页中的选项卡效果

  9. 利用js制作异步验证ajax方法()

    如何利用js写ajax异步验证.代码如下: window.onload = function(){ var name = document.getElementById('register-name- ...

随机推荐

  1. Android studio初次安装启动时弹出unable to access android sdk add-on list提示的解决方法

    一.问题描述 初次安装Android Studio,启动后,报错如下: unable to access android sdk add-on lis 如图: 二.原因分析 AS启动后,会在默认路径下 ...

  2. Codeforces Numbers 题解

    这题只需要会10转P进制就行了. PS:答案需要约分,可以直接用c++自带函数__gcd(x,y). 洛谷网址 Codeforces网址 Code(C++): #include<bits/std ...

  3. WordPress 文章目录插件 Easy Table of Contents 配置教程

    今天介绍一款目录插件,本站已经使用一段时间,感觉不错,实现效果可以看文章页右侧边栏有目录,点击目录内容会快速定位.推荐给大家. 一.安装Easy Table of Contents 插件主页搜索Eas ...

  4. C++进程间通讯方式

    1.剪切板模式. 在MFC里新建两个文本框和两个按钮,点击发送按钮相当于复制文本框1的内容,点击接收按钮相当于粘贴到文本框2内: 发送和接收按钮处功能实现如下: void CClipboard2Dlg ...

  5. Flume系列一之架构介绍和安装

    Flume架构介绍和安装 写在前面 在学习一门新的技术之前,我们得知道了解这个东西有什么用?我们可以使用它来做些什么呢?简单来说,flume是大数据日志分析中不能缺少的一个组件,既可以使用在流处理中, ...

  6. FTP无法登录问题-内有网盘福利

    http://dinghuqiang.blog.51cto.com/19871/701185/ 一顿操作猛如虎,还是没解决. 然后我想想,会不会是浏览器缓存问题? 换个火狐登录看看! 哇擦!看到报错了 ...

  7. docker容器添加对外映射端口

    一般在运行容器时,我们都会通过参数 -p(使用大写的-P参数则会随机选择宿主机的一个端口进行映射)来指定宿主机和容器端口的映射,例如 docker run -it -d --name [contain ...

  8. mysql 时间与字符串相互转换

    时间.字符串.时间戳之间的相互转换:date转字符串.date转时间戳.字符串转date.字符串转时间戳.时间戳转date,时间戳转字符串用法 涉及的函数 date_format(date, form ...

  9. 痞子衡嵌入式:史上最强i.MX RT学习资源汇总(持续更新中...)

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是i.MX RT学习资源. 类别 资源 简介 官方汇总 i.MXRT产品主页 恩智浦官方i.MXRT产品主页,最权威的资料都在这里,参考手 ...

  10. Unity进阶技巧 - RectTransform详解

    前言 最近要做UI,有时候需要在代码中调整改变UI控件的属性,比如位置.大小等,然而在NGUI里面,控制UI控件的位置等属性的是RectTransform这个组件,这个组件继承自Transform组件 ...