今天给大家分享一下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]

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

最新文章

  1. BZOJ 2038: [2009国家集训队]小Z的袜子(hose) [莫队算法]【学习笔记】
  2. 字符串专题:map POJ 1002
  3. mac上执行sed的编辑 -i命令报错sed: 1: &quot;test.txt&quot;: undefined label ‘est.txt’或sed: 1: &quot;2a\test\&quot;: extra characters after \ at the end of a command
  4. 配置mysql远程访问权限,大家可能掉过的那些坑~
  5. css-画三角箭头
  6. CentOS搭建Redis集群
  7. Java语言基础(六)
  8. LINUX更改时区和时间
  9. el表达式判断是否相等
  10. 浅谈OCR之Onenote 2010
  11. mybaties xml 的头部
  12. codeforces#1011C. Fly (二分,注意精度)
  13. C# 同步更新网盘和本地的文件夹及文件
  14. centos7如何查找文件?
  15. dns与wins的区别
  16. jQuery的ID选择器失效问题
  17. Centos配置iptables开放ftp服务
  18. 【Docker-机器学习-神经网络】初始这些新鲜的概念
  19. 6.2 Controllers -- Representing Multipe Models
  20. iso、ios、osi的区别

热门文章

  1. android canvas drawtext 字高
  2. python全栈开发第6天
  3. RobotFramework测试库速查表
  4. go get命令在go mod目录下与正常目录执行的区别
  5. LC 357. Count Numbers with Unique Digits
  6. LC 358. Rearrange String k Distance Apart
  7. 发布机制-A/B 测试:百科
  8. nodejs本版问题
  9. html5内容快速学习
  10. Appium移动自动化测试(五)之应用操作