首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

漫画:如何在数组中找到和为 “特定两个数?

我们来举个例子,给定下面这样一个整型数组(题目假定数组不存在重复元素): 我们随意选择一个特定,比如13,要求找出两数之和等于13全部组合。...由于12+1 = 13,6+7 = 13,所以最终输出结果(输出是下标)如下: 【1, 6】 【2, 7】 小灰想表达思路,是直接遍历整个数组,每遍历到一个元素,就和其他元素相加,看看和是不是等于那个特定...第1轮,用元素5和其他元素相加: 没有找到符合要求两个元素。 第2轮,用元素12和其他元素相加: 发现12和1相加结果是13,符合要求。 按照这个思路,一直遍历完整个数组。...在哈希表中查找1,查到了元素1下标是6,所以元素12(下标是1)和元素1(下标是6)是一对结果: 第3轮,访问元素6,计算出13-6=7。...在哈希表中查找7,查到了元素7下标是7,所以元素6(下标是2)和元素7(下标是7)是一对结果: 按照这个思路,一直遍历完整个数组即可。

3K64

如何从两个List中筛选出相同

问题 现有社保卡和身份证若干,想要匹配筛选出一一对应社保卡和身份证。 转换为List socialList,和List idList,从二者中找出匹配社保卡。...采用Hash 通过观察发现,两个list取相同部分时,每次都遍历两个list。那么,可以把判断条件放入Hash中,判断hash是否存在来代替遍历查找。...如此推出这种做法时间复杂度为O(m,n)=2m+n. 当然,更重要是这种写法更让人喜欢,天然不喜欢嵌套判断,喜欢扁平化风格。...事实上还要更快,因为hash还需要创建更多对象。然而,大部分情况下,n也就是第二个数组长度是大于3。这就是为什么说hash要更好写。...当然,另一个很重要原因是lambda stream运算符号远比嵌套循环让人喜爱。

6K90

leetcode之两个相同字符之间最长子字符串

序 本文主要记录一下leetcode之两个相同字符之间最长子字符串 题目 给你一个字符串 s,请你返回 两个相同字符之间最长子字符串长度 ,计算长度时不含这两个字符。...如果不存在这样子字符串,返回 -1 。 子字符串 是字符串中一个连续字符序列。 示例 1: 输入:s = "aa" 输出:0 解释:最优子字符串是两个 'a' 之间空子字符串。...示例 4: 输入:s = "cabbac" 输出:4 解释:最优子字符串是 "abba" ,其他非最优解包括 "bb" 和 "" 。...,在遍历字符串时候,遇到相同字符时候,计算前后下标的差来得出子字符串长度,然后通过对比记录最长子字符串长度。...doc 两个相同字符之间最长子字符串

2.1K10

老生常谈,判断两个区域是否具有相同

标签:Excel公式练习 这个问题似乎很常见,如下图1所示,有两个区域,你能够使用公式判断它们是否包含相同吗?...如果两个区域包含相同,则公式返回TRUE,否则返回FALSE。 关键是要双向比较,即不仅要以range1为基础和range2相比,还要以range2为基础和range1相比。...最简洁公式是: =AND(COUNTIF(range1,range2),COUNTIF(range2,range1)) 这是一个数组公式,输入完后要按Ctrl+Shift+Enter组合键。...还有下面的一系列数组公式: =IF(ISERROR(SUM(MATCH(range1,range2,0)*MATCH(range2,range1,0))),FALSE,TRUE) 或者: =IF(ISERROR...看到了吧,同样问题,各种函数各显神通,都可以得到想要结果。仔细体味一下上述各个公式,相信对于编写公式水平会大有裨益。 当然,或许你有更好公式?欢迎留言。

1.7K20

Android 中两个Activity 之间问题

Android 中两个Activity 之间问题 在Android项目中,有时需要一些全局静态变量来保存一些数据,这样在关闭赋值界面后,其他页面还可以调用这些数据。...这是会影响到系统性能。那么在android中可不可以不通过这种方式来传递呢? 今天自己做了一个小demo,感觉还不错:不通过全局静态变量而实现两个Activity之间传递数据。...btnReceiveButton.setOnClickListener(new OnClickListener() { public void onClick(View v) { //最后参数一定要和发送方相同...之间通过Intent传,那么如果有三个Activity是依次显示,但是,第三个Activity需要用到第一个Activity中,这种方法是否还能够发挥功效?...是否还有其他更好方法? 以上就是Android 两个Activity 之间问题,如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站支持!

2.1K31

两个相同字符之间最长子字符串

题目 给你一个字符串 s,请你返回 两个相同字符之间最长子字符串长度 ,计算长度时不含这两个字符。如果不存在这样子字符串,返回 -1 。 子字符串 是字符串中一个连续字符序列。...示例 1: 输入:s = "aa" 输出:0 解释:最优子字符串是两个 'a' 之间空子字符串。 示例 2: 输入:s = "abca" 输出:2 解释:最优子字符串是 "bc" 。...示例 3: 输入:s = "cbzxy" 输出:-1 解释:s 中不存在出现出现两次字符,所以返回 -1 。...示例 4: 输入:s = "cabbac" 输出:4 解释:最优子字符串是 "abba" ,其他非最优解包括 "bb" 和 "" 。...解题 记录每个字符出现第一次位置,和最后一次位置 class Solution { public: int maxLengthBetweenEqualCharacters(string s

1.4K20

LeetCode - #4 求两个有序数组中间

难度水平:困难 描述 已知两个有序数组 nums1 和 nums2,他们数据长度分别是 n 和 m,将两个数组合并成一个新数组,返回新数组中间。...整体运行时间复杂度应该是 O(log (m+n)) 示例 示例 1 输入:nums1 = [1,3], nums2 = [2] 输出:2.00000 说明:合并后数组为 [1,2,3],中间为...2 示例 2 输入:nums1 = [1,2], nums2 = [3,4] 输出:2.50000 说明:合并后数组为 [1,2,3,4],中间为 (2 + 3) / 2 = 2.5 示例 3...要在 nums1 中找到 mid1 索引,将数组分成左右部分: nums1[0, 1, ..., mid1 - 1] | nums1[mid1, mid1 + 1, ..., m] nums2[0,...1, ..., mid2 - 1] | nums2[mid2, mid2 + 1, ..., n] 数组分后左右部分要确保: 左数 = 右数 左边最大 <= 右边最小 前往 LeetCode

65420
领券