今天给大家分享一下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. Windows上配置Mask R-CNN及运行示例demo.ipynb

    最近做项目需要用到Mask R-CNN,于是花了几天时间配置.简单跑通代码,踩了很多坑,写下来分享给大家. 首先贴上官方Mask R-CNN的Github地址:https://github.com/m ...

  2. [windows菜鸟]C#中调用Windows API的技术要点说明

    在.Net Framework SDK文档中,关于调用Windows API的指示比较零散,并且其中稍全面一点的是针对Visual Basic .net讲述的.本文将C#中调用API的要点汇集如下,希 ...

  3. 关于ansbile

    YAML语法规则 规则一:缩进(一个缩进两空格,注意一定不用tab) 规则二:冒号(每个冒号后一定要有空格) 规则三:短横线 - (短横线后面要空格) 编写案例 ansible-playbook -- ...

  4. vue-template-compiler作用

    vue-template-compiler的作用是什么: 看起来 template-compiler是给parse函数使用的, 那么parse函数是干什么的呢 先看一下parse的结果: 结论:使用v ...

  5. k8s报错日志查看

    看系统日志 cat /var/log/messages 用kubectl 查看日志 # 注意:使用Kubelet describe 查看日志,一定要带上 命名空间,否则会报如下错误[root@node ...

  6. SparkCore的性能优化

    1.广播变量 1.1. Spark提供的Broadcast Variable,是只读的,并且在每个节点上只会有一份副本,而不会为每个task都拷贝一份副本 1.2.它的最大作用,就是减少变量到各个节点 ...

  7. 调用redis封装好的JedisUtils接口实现锁库

    1.在进行数据库操作的方法前先定义一个key值,并添加一个能区别每个key的标识 2.首先判断如果定义的key值存在的话,就直接return方法,如果不存在的话,就把key值放在jedisutil中, ...

  8. Linux 操作命令简

    一.Linux命令及获取帮助 1.Linux命令的格式1)了解Linux命令的语法格式:命令 [选项] [参数]2)掌握命令格式中命令.选项.参数的具体含义a)命令:告诉Linux(UNIX)操作系统 ...

  9. 华为HCNA乱学Round 4:RIP

  10. hdfs(分布式文件系统)优缺点

    hdfs(分布式文件系统) 优点 支持超大文件 支持超大文件.超大文件在这里指的是几百M,几百GB,甚至几TB大小的文件.一般来说hadoop的文件系统会存储TB级别或者PB级别的数据.所以在企业的应 ...