python请手写冒泡排序算法_算法之冒泡排序手写之js写法andjava写法

对于经典算法,你是否也遇到这样的情形:学时觉得很清楚,可过阵子就忘了?

本系列文章帮助你解决这个问题。

其实排序算法,仔细品读他的名字就见名知意了。

比如冒泡排序就很形象,遍历n次,每次循环相邻元素两两比较,把其中大的元素往后放。例如:

用javascript写冒泡排序如下

上图演示了冒泡过程的第一次循环。其中,最大的元素5就像气泡一样逐步上升到最后一位。

我们用代码展示:

const arr = [3,9,6,1,2,4,0] ;

for(let i = 0;i

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

swap(arr,i,i+1);

}

}

console.log(arr)

其中swap函数封装了两个元素如何交换(这样是用es6的箭头函数写的,记得把swap放在用swap的上面,要先声明,相当于变量):

const swap = (arr,i,j)=>{

[arr[i],arr[j]]=[arr[j],arr[i]]

}

或者这样(普通函数,放哪里都行):

function swap(arr,i,j){

[arr[i],arr[j]]=[arr[j],arr[i]]

}

第一次遍历会把最大的元素放到倒数第一个位置上,第二次遍历会把第2大的元素放倒数第二个位置上。

以此类推。此时,我们也很容易把这n次遍历写出来:

for(let j = 0;j

for(let i = 0;i

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

swap(arr,i,i+1);

}

}

}

到这里js写的冒泡排序已经说完了。

用java写冒泡排序如下

java冒泡排序跟javascript冒泡排序肯定原理是相同的,不同的就是语言不同,下面就来实现java的冒泡排序。

int[] arr = new int[]{6, 2, 5, 4, 9, 1, 3, 0};

for (int j = 0; j < arr.length; j++) {

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

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

swap(arr, i, i + 1);

}

}

}

其中swap是一个静态方法(用来调换位置):

public static void swap(int[] arr, int i, int j) {

int temp;

temp = arr[i];

arr[i] = arr[j];

arr[j] = temp;

}

到此冒泡排序就说完了,下次再说一下其他排序。

总结:冒泡排序不需要额外空间,是本地排序,相等元素是不会交换前后顺序,因而也是稳定排序,时间复杂度为O(n^2),适用于少量数据排序,但实际中用得不多。

让我们纯手写一个js继承吧

继承在前端逻辑操作中是比较常见的,今天我们就从零开始写一个js的继承方式 在es5中继承实质上是先创建子类的实例对象,然后再将父类的方法添加到this上Parent.call(this),在es6中则 ...

【机器学习】k-近邻算法应用之手写数字识别

上篇文章简要介绍了k-近邻算法的算法原理以及一个简单的例子,今天再向大家介绍一个简单的应用,因为使用的原理大体差不多,就没有没有过多的解释. 为了具有说明性,把手写数字的图像转换为txt文件,如下图所 ...

手写CSS&plus;js实现radio单选按钮

有的时候我们需要用长得漂亮一点的单选按钮,那么,就要抛弃原有的自己来写,下面就是我实现的

PHP冒泡排序-手写

利用神经网络算法的C#手写数字识别

欢迎大家前往云+社区,获取更多腾讯海量技术实践干货哦~ 下载Demo - 2.77 MB (原始地址):handwritten_character_recognition.zip 下载源码 - 70. ...

第三篇:基于K-近邻分类算法的手写识别系统

前言 本文将继续讲解K-近邻算法的项目实例 - 手写识别系统. 该系统在获取用户的手写输入后,判断用户写的是什么. 为了突出核心,简化细节,本示例系统中的输入为32x32矩阵,分类结果也均为数字.但对 ...

几道JS代码手写面试题

几道JS代码手写面试题   (1) 高阶段函数实现AOP(面向切面编程)    Function.prototype.before = function (beforefn) {        let ...

c&plus;&plus;后台开发面试常见知识点总结(六)算法手写

链表倒转  leetcode-206 连续子数组最大和问题(和最大的连续子序列的和)   leetcode-53 输出字符串中最长的回文子串长度?  leetcode-5 一个字符串,求最长无重复子串 ...

JS &sol; Egret 单笔手写识别、手势识别

UnistrokeRecognizer 单笔手写识别.手势识别 UnistrokeRecognizer : https://github.com/RichLiu1023/UnistrokeRecogn ...

随机推荐

【JAVA并发编程实战】2、对象的组合

1. 设计线程安全的类 1.找出构成对象状态的所有变量 2.找出约束状态变量的不变性条件 3.建立对象状态的并发访问管理策略 package cn.xf.cp.ch04; /** * *功能:JAVA ...

SQL Server 创建表 添加主键 添加列常用SQL语句

--删除主键 alter table 表名 drop constraint 主键名 --添加主键 alter table 表名 add constraint 主键名 primary key(字段名1, ...

Hadoop - Kylin On OLAP

1.概述 Apache Kylin是一个开源的分布式分析引擎,提供SQL接口并且用于OLAP业务于Hadoop的大数据集上,该项目由eBay贡献于Apache. 2.What is Kylin 在使用 ...

data abstractions 数据抽象

Computer Science An Overview _J. Glenn Brookshear _11th Edition In this chapter we investigate how d ...

UVaLive 7371 Triangle &lpar;水题,判矩形&rpar;

题意:给定两个三角形,问你能不能拼成矩形. 析:很明显,要想是矩形,必须是四个角是直角,那么三角形必须是直角三角形,然后就是只能斜边相对,然后呢?就没了. 代码如下: #pragma comment( ...

CentOS6&period;3系统安装SCP命令

原文:http://www.111cn.net/sys/CentOS/58387.htm CP使用SSH协议在Linux系统中进行文件传输,但我最小安装的CentOS 6.3没有该命令.  代码如下 ...

常见dos命令

打开控制面板:win+r  control 服务: win+r  services.msc

mac下更新自带的PHP版本到5&period;6

OS X 10.11自带的PHP版本是PHP 5.5.x,如果我们想更新PHP的版本到5.6或者是7.0该怎么办呢? 下载和安装PHP 5.6 打开终端并且运行如下命令: curl -s http:/ ...

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值