今天给大家分享一下js中常用的基础算法,废话不多说,直接上代码;

1、两个数字调换顺序

  var a = ,b=
function fun(a,b){
b = b - a ;// a = 2 ; b = 2
a = a + b // a = 4 ; b = 2;
b = a - b;// a = 4 ; b = 2
return [a,b]
}
fun(a,b) // a = 4 ;b = 2

2、对象排序,安装对象中的id排序对象的位置;

  var arr = [
{ nama: 'a', id: 55 },
{ nama: 'b', id: 39 },
{ nama: 'c', id: 59 },
]
var newarr = arr.sort((a,b)=>{
return a.id - b.id;
}) console.log(newarr)
// {nama: "b", id: 39}
// {nama: "a", id: 55}
// {nama: "c", id: 59}

3、冒泡排序

function fun(arr) {
for (let i = 0; i < arr.length - 1; i++) {
for (let j = 0; j < arr.length - i - 1; j++) {
if (arr[j] > arr[j + 1]) {
let temp = arr[j + 1];
arr[j + 1] = arr[j];
arr[j] = temp;
}
}
}
return arr;
}
console.log(fun([1, 5, 2, 8, 3, 7])); // [1, 2, 3, 5, 7, 8]

4、随机出现不同的数字

function fun (num){
var arr = [];
while(arr.length < num){
var s = parseInt(Math.random() * 100);
// 如果这个数组中没有这一项才能进去;
if(!arr.includes(s)){
arr.push(s)
}
}
return arr;
}
// 输入几项就会输出几项不同的数组;
fun(3)

5、字符串大小写互换

function fun (n){
let str = ''
for(let i = 0;i < n.length;i++){
if(n[i] == n[i].toUpperCase()){
str += n[i].toLowerCase()
}else{
str += n[i].toUpperCase();
}
}
return str
}
fun('AbCd') // aBcD

6、数组随机打乱

function fun(arr){
return arr.sort( ()=>{
return Math.random() > 0.5 ? 1 : -1
})
}
fun([1,2,3,4,5])

7、数组扁平化-把多维数组转为一维数组

function fun (arr){
var result = [];
arr.forEach(item =>{
if(Array.isArray(item)){
result.push(...fun(item ))
}else{
result.push(item)
}
})
return result
}
fun([1,[2,[3,[4,[5]],6,[7]]]]); // [1, 2, 3, 4, 5, 6, 7]

8、数组去重

function fun(arr){
var newarr = [];
for(let i = 0; i < arr.length;i++){
if(!newarr.includes(arr[i])){
newarr.push(arr[i])
}
}
return newarr;
}
fun([1,1,1,2,3,3]) // [1, 2, 3]

9、数组尾部删除,增加到前面;

//  用户不输入,默认1项;
function fun(arr,num = 1){
for(let i = 0 ; i < num;i++){
arr.unshift(arr.pop())
}
return arr;
}
fun([1,2,3,4] // [4, 1, 2, 3]

10、统计字符出现的次数;

function fun (arr){
var obj = {};
for(let i= 0 ; i <arr.length;i++){
if(obj.hasOwnProperty(arr[i])){
obj[arr[i]]++;
}else{
obj[arr[i]] = 1;
}
}
let cont = 0, num;
for(let k in obj){
if(obj[k] > cont){
cont = obj[k];
num = k
}
}
return cont // 出现最多的次数
return num // 出现最多的数字
return obj // 统计所有字符出现的次数
} fun('1223334444')

11、删除数组出出现次数大于2的数组;

function fun (arr){
var obj = {};
for(let i= 0 ; i <arr.length;i++){
if(obj.hasOwnProperty(arr[i])){
obj[arr[i]]++;
}else{
obj[arr[i]] = 1;
}
}
let newarr = [];
for(let k in obj){
if(obj[k] <= 2){
newarr.push(obj[k])
}
}
return newarr;
}
fun([1,2,2,3,3,3,4,4,4,4]) // [1, 2]

如果大家喜欢的话,欢迎关注“前端伪大叔”我将为您不间断的分享前端学习知识!

今天给大家分享一下js中常用的基础算法的更多相关文章

  1. js中常用的操作

    1.js中常用的数组操作 2.js中常用的字符串操作 3.js中常用的时间日期操作 4.定时器

  2. 基础篇:1.JavaScript运行在html中,引用有几种方式?—— 6.js中常用的输出方式?

    书接上文,上文提到若干条JavaScript的基础性知识,大部分都是一些概念性的东西,本着认真严谨的态度,我们要认真对待,有些条目的问题是某个知识点的周边延伸,为节约篇幅,就一起整理了,如有描述不对的 ...

  3. Js中常用的字符串,数组,函数扩展

    由于最近辞职在家,自己的时间相对多一点.所以就根据prototytpeJS的API,结合自己正在看的司徒大神的<javascript框架设计>,整理了下Js中常用一些字符串,数组,函数扩展 ...

  4. 【温故知新】——原生js中常用的四种循环方式

    一.引言 本文主要是利用一个例子,讲一下原生js中常用的四种循环方式的使用与区别: 实现效果: 在网页中弹出框输入0   网页输出“欢迎下次光临” 在网页中弹出框输入1   网页输出“查询中……” 在 ...

  5. JS中常用开发知识点

     JS中常用开发知识点 1.获取指定范围内的随机数 2.随机获取数组中的元素 3.生成从0到指定值的数字数组 等同于: 4.打乱数字数组的顺序 5.对象转换为数组 //注意对象必须是以下格式的才可以通 ...

  6. js中常用的对象—String的属性和方法

    今天说一下,js中常用的内置对象——String对象它有以下几个常用的属性:lengthprototype 有以下几个常用的方法:parseInt()转换为数字parseFloat()转换为数字,支持 ...

  7. js中常用的对象—Array的属性和方法

    今天说一下,js中常用的内置对象——Array对象 Array常用属性: length prototype :给系统对象添加属性和方法 Array常用方法: Array.prototype.sum = ...

  8. js中常用追加元素的几种方法

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  9. Java中常用的查找算法——顺序查找和二分查找

    Java中常用的查找算法——顺序查找和二分查找 神话丿小王子的博客 一.顺序查找: a) 原理:顺序查找就是按顺序从头到尾依次往下查找,找到数据,则提前结束查找,找不到便一直查找下去,直到数据最后一位 ...

随机推荐

  1. C# how to properly make a http web GET request

    C# how to properly make a http web GET request EDIT 23/11/17 Updated to throw out examples using asy ...

  2. Java-JVM 栈帧(Stack Frame)

    一.概述 栈帧位置 JVM 执行 Java 程序时需要装载各种数据到内存中,不同的数据存放在不同的内存区中(逻辑上),这些数据内存区称作运行时数据区(Run-Time Data Areas). 其中 ...

  3. [转]html中meta作用

    meta是html语言head区的一个辅助性标签.几乎所有的网页里,我们可以看到类似下面这段的html代码:  <head>  <meta http-equiv="cont ...

  4. PLSQL报错: ORA-12514:TNS:监听程序当前无法识别连接描述符中请求的服务

    一开始吓尿了,以为自己动着什么东西了把数据库玩坏了,谁知道打开服务发现服务没启动........... 我们要确保数据库服务是启动状态

  5. 浏览器端-W3School-HTML:HTML DOM Video 对象

    ylbtech-浏览器端-W3School-HTML:HTML DOM Video 对象 1.返回顶部 1. HTML DOM Video 对象 Video 对象 Video 对象是 HTML5 中的 ...

  6. ubuntu下tomcat运行不起来解决

    报错Neither the JAVA_HOME nor the JRE_HOME environment variable is definedAt least one of these enviro ...

  7. 使用Statement对象执行静态sql语句

    import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; import java ...

  8. 安装VMTool

    一.       安装VMTool 开启虚拟机,然后在VMware上选虚拟机->安装VMTool 如果提示光驱被占用就先用root登录 在命令行中挂载光盘   #mount /dev/cdrom ...

  9. 【HANA系列】【第五篇】SAP HANA XS的JavaScript API详解

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[HANA系列][第五篇]SAP HANA XS ...

  10. socket之UDP协议,并发编程介绍,操作系统发展史

    socket之UDP协议 1.UDP协议 UDP 是User Datagram Protocol的简称, 中文名是用户数据报协议,是OSI(Open System Interconnection 参考 ...