首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

计算数组中“包围”数组外的不同值的值

,可以通过以下步骤实现:

  1. 首先,我们需要找到数组中的最大值和最小值,以确定数组的范围。
  2. 然后,我们可以创建一个包含所有可能值的新数组,从最小值到最大值。
  3. 接下来,我们遍历原始数组,将出现的值在新数组中标记为已出现。
  4. 最后,我们遍历新数组,找到未被标记的值,即为“包围”数组外的不同值。

下面是一个示例的JavaScript代码实现:

代码语言:txt
复制
function findDifferentValues(arr) {
  // 找到数组的最大值和最小值
  let min = Math.min(...arr);
  let max = Math.max(...arr);

  // 创建新数组
  let newArr = Array.from({ length: max - min + 1 }, (_, i) => i + min);

  // 标记已出现的值
  for (let i = 0; i < arr.length; i++) {
    let index = arr[i] - min;
    if (index >= 0 && index < newArr.length) {
      newArr[index] = null;
    }
  }

  // 找到未被标记的值
  let differentValues = newArr.filter(value => value !== null);

  return differentValues;
}

// 示例用法
let arr = [1, 2, 3, 5, 7, 2, 4, 6];
let result = findDifferentValues(arr);
console.log(result); // 输出 [8, 9, 10]

这段代码通过遍历原始数组,并在新数组中标记已出现的值,然后找到未被标记的值,即为“包围”数组外的不同值。在示例中,原始数组为 [1, 2, 3, 5, 7, 2, 4, 6],计算结果为 [8, 9, 10]

对于这个问题,腾讯云没有特定的产品或服务与之直接相关。但是,腾讯云提供了丰富的云计算服务和解决方案,可以满足各种应用场景的需求。您可以参考腾讯云官方文档了解更多相关信息:腾讯云产品与服务

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

js如何判断数组包含某个特定_js数组是否包含某个

array.indexOf 判断数组是否存在某个,如果存在返回数组元素下标,否则返回-1 let arr = ['something', 'anything', 'nothing',...anything']; let index = arr.indexOf('nothing'); # 结果:2 array.includes(searchElement[, fromIndex]) 判断一个数组是否包含一个指定...numbers.includes(8); # 结果: true result = numbers.includes(118); # 结果: false array.find(callback[, thisArg]) 返回数组满足条件第一个元素...item.id == 3; }); # 结果: Object { id: 3, name: "nothing" } array.findIndex(callback[, thisArg]) 返回数组满足条件第一个元素索引...方法,该方法返回元素在数组下标,如果不存在与数组,那么返回-1; 参数:searchElement 需要查找元素

18.4K40
  • 如何删除 JavaScript 数组

    falsy 有时写作 falsey 在 JavaScript 中有很多方法可以从数组删除元素,但是从数组删除所有虚最简单方法是什么?...为了回答这个问题,我们将仔细研究 truthy 与 falsy 和类型强制转换。 ---- 算法说明 从数组删除所有虚。...解决方案:.filter( ) 和 Boolean( ) 理解问题:我们有一个作为输入数组。目标是从数组删除所有的虚然后将其返回。...换句话说,.filter() 遍历数组每个元素并保留通过其中某个测试所有元素。数组未通过该测试所有元素都被过滤掉了 —— 被删除了。...知道如果我们将输入数组每个都转换为布尔,就可以删除所有为 false 元素,这就满足了此挑战要求。 算法: 确定 arr 哪些是虚。 删除所有虚

    9.5K20

    java如何打印数组,Java打印数组元素

    大家好,又见面了,我是你们朋友全栈君。 本篇文章帮大家学习java打印数组元素,包含了Java打印数组元素使用方法、操作技巧、实例演示和注意事项,有一定学习价值,大家可以用来参考。...以下实例演示了如何通过重载 MainClass 类 printArray 方法输出不同类型(整型, 双精度及字符型)数组:public class MainClass { public static...5.5, 6.6, 7.7 }; Character[] characterArray = { ‘H’, ‘E’, ‘L’, ‘L’, ‘O’ }; System.out.println(“输出整型数组...(“\n输出字符型数组:”); printArray(characterArray); } } 以上代码运行输出结果为: 输出整型数组: 1 2 3 4 5 6 输出双精度型数组: 1.1 2.2 3.3...4.4 5.5 6.6 7.7 输出字符型数组: H E L L O 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/131413.html原文链接:https:/

    4.3K10

    数组实际操作求数组数字最大

    DOCTYPE html>          一维数组最大              //一维数组初始         var num=[1,56,23,954,6,43,87,3,5,55];         function max(arr...){             var temp=arr[0];//初始化最大默认为数组第0号元素             //遍历出数组全部元素         for(var i=0;i<arr.length...;i++){             //用初始化和遍历出比较大于初始化,则将遍历后即为最大             if(arr[i]>temp){                 temp...=arr[i];             }         }         return temp;//将比较最大返回给temp         }                  var re

    1.8K30

    php 数组根据找key,从数组查找key对应 – key

    除了楼上给出分解num后通过array_key_exists在arr数组寻找相应后在implode到一起之外。...exists(key):确认一个key是否存在del(key):删除一个keytype(key):返回类型keys(pattern):返回满足给定pattern所有keyrandomkey:随机…...在此基础上,redis支持各种不同方式排序。...PHP可以模拟实现Hash表增删改查。通过对key映射到数组一个位置来访问。映射函数叫做Hash函数,存放记录数组称为Hash表。 Hash函数把任意长度和类型key转换成固定长度输出。...不同key可能拥有相同… 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/163582.html原文链接:https://javaforall.cn

    11.6K20

    分割数组最大

    问题描述: 给定一个非负整数数组和一个整数 m,你需要将这个数组分成 m 个非空连续子数组。设计一个算法使得这 m 个子数组各自和最大最小。...解决方案 贪心+二分 该问题是一道经典贪心+二分问题。 不妨设k为子数组最大和,由题意可知存在如下结论: 若以子数组和最大为k可以分割出m个子数组,则以k+ 1也一定能分割出m个子数组。...由该结论我们就可以对k从[max(nums), sum(nums)]区间中二分查找出满足条件k最小。上式中下界max(nums)为当前数组最大,sum(nums)为当前数组之和。...上式left为当前下界,right为当前上界。...dp[i - 1] [k - 1]为前段最大子数组和,max(…)是为了获得最大子数组和,外面的min(…)是为选出所有分割子数组和最大最小那个。

    4.4K10

    Gas 优化:Solidity 使用动态数组

    理想情况下,这些数据存储在一个小数值动态数组。 在这篇文章例子,我们研究了在 Solidity 中使用动态数组是否比引用数组或类似解决方案在处理这些小数值时更高效。...可能动态数组 在 Solidity ,只有 storage 类型有动态数组。memory 类型数组必须有固定长度,并且不允许使用push()来附加元素。...在下面的代码,我们将数组长度在存储在256位(32字节)机器码最高位。...one-hundred & twenty-four 2bit EVs uint1[](248 "") uint1d248 8 two-hundred & forty-eight 1bit EVs 不同项目需要特定数组类型...注意uint1d248数值数组。它让我们可以有效地将多达248个1位元素(代表布尔)编码到1个 EVM 字

    3.3K30

    数组是否重复问题

    , 10 1月 2021 作者 847954981@qq.com 我编程之路, 算法学习 数组是否重复问题 public static ArrayList repeat(int...// 否则将当前位置设置为1 exists[value] = 1; } } return result; } 分析: 在明确数组数是有一定范围情况下...,可以先定义另一个数组exist 该数组长度为原数组范围。...创建一个数组result储存重复 遍历一遍原数组,每遍历到一个数就把其exist对应位置(如遍历到10则exist第10个位置)书变为1。...如果再次遍历到相同数,判断到exist对应位置为1则代表有重复数并输出进result数组 此方法可以用于string 在一个string 利用string.charAt(int)来获取每个位置字符

    1.5K20

    VBA数组排序_vba函数返回 数组

    大家好,又见面了,我是你们朋友全栈君。 我们平时用表格排序,只相对来说是在在表格升序降序。今天就好奇如果数组实现排序 他是怎么实现呢。...它工作原理是:第一次从待排序数据元素中选出最小(或最大)一个元素,存放在序列起始位置,然后再从剩余未排序元素寻找到最小(大)元素,然后放到已排序序列末尾。...MinIndex = i '记录最小索引位置 For j = MinIndex + 1 To UBound(arr) If arr(j, 1) < MinValue Then MinValue...= arr(j, 1) MinIndex = j End If Next '以此和当前最小做对比,比较出后面的最小并记录 及索引位置 '因为小我们都放在最前面,所以遍历只需从当前后面开始就可以了...,只会有两个可能,一种是MinIndex > i(在默认最小后面有比当前还小),另一种MinIndex = i :(在最小后面没有找到比当前再小)。

    3.4K40

    Javascript获取数组最大和最小方法汇总

    比较数组数值大小是比较常见操作,下面同本文给大家分享四种放哪广发获取数组中最大和最小,对此感兴趣朋友一起学习吧 比较数组数值大小是比较常见操作,比较大小方法有多种,比如可以使用自带...apply能让一个方法指定调用对象与传入参数,并且传入参数是以数组形式组织。...alert(Math.min.apply(null, a));//最小 多维数组可以这么修改: var a=[1,2,3,[5,6],[1,4,8]]; var ta=a.join(",").split...(",");//转化为一维数组 alert(Math.max.apply(null,ta));//最大 alert(Math.min.apply(null,ta));//最小 以上内容是小编给大家分享...Javascript获取数组最大和最小方法汇总,希望大家喜欢。

    7.1K50

    寻找旋转排序数组最小

    一、题目描述 已知一个长度为 n 数组,预先按照升序排列,经由 1 到 n 次 旋转 后,得到输入数组。...给你一个元素 互不相同 数组 nums ,它原来是一个升序排列数组,并按上述情形进行了多次旋转。请你找出并返回数组 最小元素 。...你必须设计一个时间复杂度为 O(log n) 算法解决此问题。 二、题目解析 本题也是典型自身数组顺序不是有序,但是仍然去寻找二段性去解决。...我们根据旋转数组特性去抽象数据范围如下: 我们要求最小就是C点,上图明显给我们二段性提示,我们比较基准就是D点。 这样我们就可以套入二分模板去解决。...right) { mid = left + (right-left)/2; if(nums[mid] < nums[len-1])//将数组最后一个元素作为参考

    7610

    布尔数组状态压缩

    LeetCode题是关于二维矩阵图论建模,像下面这样: ? 图论建模 二维矩阵可以不产生一个图结构,直接在二维矩阵上计算。...相应地,会设定一个布尔数组visited[ i ] [ j ],表示某一个位置是否被遍历,true表示被遍历,false表示未被遍历。...这里就不进行多介绍了,因为本篇介绍布尔数组压缩状态小技巧,再讲三维矩阵图论建模就偏了,了解二维矩阵就好了。...在进行二维矩阵图论建模,如果不转成图形结构,直接在二维矩阵上计算,我们会设定一个布尔类型二维数组visited,数组表示图某个节点是否遍历过。...= 0) visited -= 1<<i; 举一反三,学会了二进制数组压缩成一个数字状态,多进制数组也同样可以压缩状态,只需要找到最大那个数就可以了。

    1.5K30
    领券