利用 js 的一些函数调用,排序
编辑器: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 min = 100;
for (let i = 0; i < arr.length; i++){
if (arr[minIndex] > arr[i]){
minIndex = i;
}
}
console.log(minIndex,arr[minIndex]);
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;
}
inserSort(arr);
console.log(arr);
//外循环确定当前要向前插入元素的位置
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;
}
}
insertSort(arr);
console.log(arr);
//外循环确定当前要向前插入元素的位置
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;
}
}
let temp = array[j];
array[j] = array[right];
array[right] = temp;
quickSort(array,j + 1,right);
}
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;
}
利用 js 的一些函数调用,排序的更多相关文章
- 使用 js 实现十大排序算法: 堆排序
使用 js 实现十大排序算法: 堆排序 堆排序(Heapsort)是指利用堆这种数据结构所设计的一种排序算法. 大顶堆:每个节点的值都大于或等于其子节点的值,在堆排序算法中用于升序排列: 小顶堆:每个 ...
- 利用JS脚本通过getAttribute()和setAttribute()等对CSS样式进行操作
HTML中引入CSS样式的方式有三种: 1.最常用的,引入样式表,在样式表中编写样式,引入方式如下:<link href="css/style.css" rel=" ...
- 利用脚本修改SQL SERVER排序规则
利用脚本修改SQL SERVER排序规则 编写人:CC阿爸 2014-3-1 l 今年的一项重要工作是对公司所用系统进行繁简的转换,程序转成简体基本很容易解决,但数据库转换成简体,就没那么容易了.经 ...
- JS 数据类型转换-转换函数、强制类型转换、利用js变量弱类型转换
1. 转换函数: js提供了parseInt()和parseFloat()两个转换函数.前者把值转换成整数,后者把值转换成浮点数.只有对String类型调用这些方法,这两个函数才能正确运行:对其他类型 ...
- 利用js制作html table分页示例(js实现分页)
有时候table的列数太长,不利于使用者查询,所以利用JS做了一个table的分页,以下为相关代码 一.JS代码 <script type="text/javascript" ...
- 利用JS实现闪烁字体
以下为在JSP文件中,利用JS实现闪烁字体的代码: HTML代码: <div id="blink">一段会闪烁的字</div> JavaScript代码: ...
- 利用JS实现HTML TABLE的分页
有时候table的列数太长,不利于使用者查询,所以利用JS做了一个table的分页,以下为相关代码 一.JS代码 <script type="text/javascript" ...
- 利用js闭包获取索引号
以tab选项卡效果为例: 网页中的选项卡效果
- 利用js制作异步验证ajax方法()
如何利用js写ajax异步验证.代码如下: window.onload = function(){ var name = document.getElementById('register-name- ...
随机推荐
- Factory Method工厂方法模式
定义一个用于创建对象的接口,让子类决定将哪一个类实例化.Factory Method使一个类的实例化延迟到其子类,属于创建型模式 在此模式中,工厂父类负责定义创建产品对象的公共接口,而工厂子类负责生产 ...
- FreeSql (八)插入数据时指定列
插入数据时指定列,和忽略列对应,未被指定的列将被忽略. var connstr = "Data Source=127.0.0.1;Port=3306;User ID=root;Passwor ...
- spring aop 之链式调用
关关雎鸠,在河之洲.窈窕淑女,君子好逑. 概述 AOP(Aspect Orient Programming),我们一般称为面向方面(切面)编程,作为面向对象的一种补充,用于处理系统中分布于各个模块的横 ...
- 超级密码(BFS)
Problem Description Ignatius花了一个星期的时间终于找到了传说中的宝藏,宝藏被放在一个房间里,房间的门用密码锁起来了,在门旁边的墙上有一些关于密码的提示信息: 密码是一个C进 ...
- Java第三次作业第五题
5. [问题描述]Fibonacci序列处理 从文件in.txt中读取第一个数作为Fibonacci数列的开始数n,读取第二个数,作为需要写入的数的个数m. 将从n开始的m个Fibonacci数列写入 ...
- Android手机QQ文件夹解析
注:切勿修改手机QQ文件夹,以免造成不必要的使用问题及无法修复的数据丢失] 安卓手机QQ tencent文件夹解析 QQ下载的聊天背景:tencent→MobileQQ→system_backgrou ...
- selenium-01-简介
一.Selenium是什么? Selenium是ThroughtWorks公司一个强大的开源Web功能测试工具系列,本系列现在主要包括以下4款: 1.Selenium Core:支持DHTML的测试案 ...
- cvc-complex-type.2.3: Element 'dependency' cannot have character [children], because the type's cont
直接复制网上的pom引入,报错 解决:自己手动输入一遍,不用直接复制,因为复制的时候,项目中编码跟网页上编码不一致,很容易导致出问题.
- redis常用笔记(第一版)
1.SINTER 说明:多key之间取交集数据 key1 = {a,b,c,d} key2 = {c} key3 = {a,c,e} SINTER key1 key2 key3 = {c} 2.sad ...
- VS Code配置Go语言开发环境(建议使用goland)
VS Code是微软开源的一款编辑器,插件系统十分的丰富.本文就介绍了如何使用VS Code搭建Go语言开发环境. VS Code配置Go语言开发环境 说在前面的话,Go语言是采用UTF8编码的,理论 ...