今天给大家分享一下js中常用的基础算法
今天给大家分享一下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中常用的基础算法的更多相关文章
- js中常用的操作
1.js中常用的数组操作 2.js中常用的字符串操作 3.js中常用的时间日期操作 4.定时器
- 基础篇:1.JavaScript运行在html中,引用有几种方式?—— 6.js中常用的输出方式?
书接上文,上文提到若干条JavaScript的基础性知识,大部分都是一些概念性的东西,本着认真严谨的态度,我们要认真对待,有些条目的问题是某个知识点的周边延伸,为节约篇幅,就一起整理了,如有描述不对的 ...
- Js中常用的字符串,数组,函数扩展
由于最近辞职在家,自己的时间相对多一点.所以就根据prototytpeJS的API,结合自己正在看的司徒大神的<javascript框架设计>,整理了下Js中常用一些字符串,数组,函数扩展 ...
- 【温故知新】——原生js中常用的四种循环方式
一.引言 本文主要是利用一个例子,讲一下原生js中常用的四种循环方式的使用与区别: 实现效果: 在网页中弹出框输入0 网页输出“欢迎下次光临” 在网页中弹出框输入1 网页输出“查询中……” 在 ...
- JS中常用开发知识点
JS中常用开发知识点 1.获取指定范围内的随机数 2.随机获取数组中的元素 3.生成从0到指定值的数字数组 等同于: 4.打乱数字数组的顺序 5.对象转换为数组 //注意对象必须是以下格式的才可以通 ...
- js中常用的对象—String的属性和方法
今天说一下,js中常用的内置对象——String对象它有以下几个常用的属性:lengthprototype 有以下几个常用的方法:parseInt()转换为数字parseFloat()转换为数字,支持 ...
- js中常用的对象—Array的属性和方法
今天说一下,js中常用的内置对象——Array对象 Array常用属性: length prototype :给系统对象添加属性和方法 Array常用方法: Array.prototype.sum = ...
- js中常用追加元素的几种方法
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- Java中常用的查找算法——顺序查找和二分查找
Java中常用的查找算法——顺序查找和二分查找 神话丿小王子的博客 一.顺序查找: a) 原理:顺序查找就是按顺序从头到尾依次往下查找,找到数据,则提前结束查找,找不到便一直查找下去,直到数据最后一位 ...
随机推荐
- Windows上配置Mask R-CNN及运行示例demo.ipynb
最近做项目需要用到Mask R-CNN,于是花了几天时间配置.简单跑通代码,踩了很多坑,写下来分享给大家. 首先贴上官方Mask R-CNN的Github地址:https://github.com/m ...
- [windows菜鸟]C#中调用Windows API的技术要点说明
在.Net Framework SDK文档中,关于调用Windows API的指示比较零散,并且其中稍全面一点的是针对Visual Basic .net讲述的.本文将C#中调用API的要点汇集如下,希 ...
- 关于ansbile
YAML语法规则 规则一:缩进(一个缩进两空格,注意一定不用tab) 规则二:冒号(每个冒号后一定要有空格) 规则三:短横线 - (短横线后面要空格) 编写案例 ansible-playbook -- ...
- vue-template-compiler作用
vue-template-compiler的作用是什么: 看起来 template-compiler是给parse函数使用的, 那么parse函数是干什么的呢 先看一下parse的结果: 结论:使用v ...
- k8s报错日志查看
看系统日志 cat /var/log/messages 用kubectl 查看日志 # 注意:使用Kubelet describe 查看日志,一定要带上 命名空间,否则会报如下错误[root@node ...
- SparkCore的性能优化
1.广播变量 1.1. Spark提供的Broadcast Variable,是只读的,并且在每个节点上只会有一份副本,而不会为每个task都拷贝一份副本 1.2.它的最大作用,就是减少变量到各个节点 ...
- 调用redis封装好的JedisUtils接口实现锁库
1.在进行数据库操作的方法前先定义一个key值,并添加一个能区别每个key的标识 2.首先判断如果定义的key值存在的话,就直接return方法,如果不存在的话,就把key值放在jedisutil中, ...
- Linux 操作命令简
一.Linux命令及获取帮助 1.Linux命令的格式1)了解Linux命令的语法格式:命令 [选项] [参数]2)掌握命令格式中命令.选项.参数的具体含义a)命令:告诉Linux(UNIX)操作系统 ...
- 华为HCNA乱学Round 4:RIP
- hdfs(分布式文件系统)优缺点
hdfs(分布式文件系统) 优点 支持超大文件 支持超大文件.超大文件在这里指的是几百M,几百GB,甚至几TB大小的文件.一般来说hadoop的文件系统会存储TB级别或者PB级别的数据.所以在企业的应 ...