封装数组排序及合并(1,2,3,4,5合并为1-5)

mergeCron = (arr) => {
let newArr = arr.sort(function (value1, value2) { return value1 - value2 })
let str = ‘’
let tmp = 0
let flag = 0
for (let i = 0; i < newArr.length; i++) {

  if (i == 0) {
    str += newArr[0]
    tmp = newArr[0]
  } else {

    if (tmp + 1 == newArr[i]) {
      tmp = newArr[i];
      flag = 1;
      if (i == newArr.length - 1) {
        str = `${str}-${tmp}`
      }
    } else {
      if (flag == 1) {
        str = `${str}-${tmp},${newArr[i]}`
        flag = 2;
        tmp = newArr[i]
      } else if (flag == 2) {
        str = `${str},${newArr[i]}`
        tmp = newArr[i]
      }
    }
    if (flag == 0) {
      str = `${str},${newArr[i]}`
      tmp = newArr[i]
    }
  }
}
return str

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
7)实现代码如下: ```javascript function getIndex(nums, target) { let map = {}; for (let i = 0; i < nums.length; i++) { let complement = target - nums[i]; if (map[complement] !== undefined) { // 如果找到了配对的数,则返回它们的下标 return [map[complement], i]; } map[nums[i]] = i; // 否则将该数记录下标 } return null; // 如果没有找到,则返回null } let nums = [2, 7, 11, 15, 3, 6, 2]; let target = 9; console.log(getIndex(nums, target)); // [0, 1] ``` 8)实现代码如下: ```javascript function result(arr1, arr2) { let res = []; let i = 0, j = 0; while (i < arr1.length && j < arr2.length) { // 按顺序合并两个数组 if (arr1[i] < arr2[j]) { res.push(arr1[i]); i++; } else { res.push(arr2[j]); j++; } } while (i < arr1.length) { // 将剩余的元素加入结果数组 res.push(arr1[i]); i++; } while (j < arr2.length) { res.push(arr2[j]); j++; } return res; } let arr1 = [2, 1, 3]; let arr2 = [5, 4, 6]; console.log(result(arr1, arr2)); // [1, 2, 3, 4, 5, 6] ``` 9)实现代码如下: ```javascript function sortNonZero(arr) { let res = []; for (let i = 0; i < arr.length; i++) { if (arr[i] !== 0) { // 如果该元素不为0,则加入结果数组 res.push(arr[i]); } } return res.sort((a, b) => a - b); // 对结果数组进行排序 } let arr = [14, 0, 5, 9, 0, 0, 2, 26, 0, 3, 16, 0]; console.log(sortNonZero(arr)); // [2, 3, 5, 9, 14, 16, 26] ``` 10)实现代码如下: ```javascript function findSum(arr) { let map = {}; let res = []; for (let i = 0; i < arr.length; i++) { let complement = 10 - arr[i]; if (map[complement] !== undefined) { // 如果找到了配对的数,则加入结果数组 res.push([complement, arr[i]]); } map[arr[i]] = i; // 否则将该数记录下标 } return res; } let arr = [1, 2, 3, 4, 5, 6, 7, 8, 9]; console.log(findSum(arr)); // [[9, 1], [8, 2], [7, 3], [6, 4]] ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值