- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
给你n
个数字,你必须找到对数,使得它们之间至少有一个数字是公共(public)的。
例如。对于 5 个数字:
2837 2818 654 35 931
答案:6
这里的对是(2837,2818), (2837,35), (2837,931), (2818,931), (654,35), (35,931)
我的尝试:我采用了一种结构来存储十进制数、数组中数字形式的数字以及该数字中的位数。。。 p>
现在,对于每个数字,我散列数组中包含索引0-9的数字,并检查所有后续数字是否已经存在任何数字。
我的尝试是O(n^2)
,这很慢。是否有另一种算法可以更快地工作?
最佳答案
了解这里的变量和常量是至关重要的。
位数是常数 (10)。所有数字组的数量 (1024) 也是如此。所有此类集合对的数量也是如此(220,或大约一百万)。让我们充分利用这一点。
让我们尝试将输入预处理为大小恒定(与输入大小无关)的数据结构中的“等效”表示。根据定义,我们随后对该恒定大小结构所做的任何操作都是恒定时间操作,因此总运行时间仅由预处理阶段渐近确定。
数据结构
创建一个包含1024个整数的数组,每个桶(索引)对应一组数字;我们希望在每个桶中存储恰好具有该组数字的输入数字的数量。
例如,3606 有数字 0、3 和 6,所以它会被计入桶 20 + 23 + 26 = 73.
算法
预处理很明显。获取下一个数字(例如 '3'
),将其转换为其值(例如 3
),现在计算相应的位(例如 1 << 3
)并将其或运算为(暂定的)桶索引变量;不同的数字位于不同的位,因此每个数字组合都有一个唯一的桶,但我们去掉了任何重复的数字。如此循环直到遇到数字分隔符;那时,桶索引是最终的,我们可以增加桶,重置桶索引并跳到下一个数字。
就是这样。剩下的就是数我们的羊。哎呀。成对的绵羊。
将每个桶与其他桶(但不是它本身)进行比较。每当两个 索引 共享一个数字(这可以使用 &
运算符确定)时,将这两个桶的内容相乘,并将乘积添加到全局维护的总和中。
将每个桶也与自身进行比较,只添加 x * (x - 1) / 2
到全局维护的总和,其中 x
是桶的内容。
那个总和就是你的结果。
性能
最坏情况:O(n)
其中 n
是输入大小。
常数因素也是有利的。我们需要每个数字或分隔符的少量指令(和 RAM 访问); constant 阶段检查一百万个桶对,在每对桶上花费一些类似的指令(不需要 RAM 访问,数据结构非常紧凑)。这快如闪电。
理论家会说这是作弊。我们假设输入长度没有上限(或者我们根本不能谈论渐近复杂性),但我们还假设我们可以将总输入长度放入一个整数变量中。哦,好吧。
更实际的程序员会注意到该算法的字母大小呈指数级增长。我们很幸运;如果我们的单词不是由数字组成,而是由除分隔符以外的任意字符组成,我们的算法仍然是渐进的线性时间算法,但与可以轻松处理高达兆字节的朴素算法相比,它对于任何输入都慢得无法使用一次输入。
关于algorithm - 至少共享一个数字的对数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11499157/
我需要一个带有条件的正则表达式: 最少 6 个字符,最多 50 个字符 必须包含 1 个字母 必须包含 1 个数字 可能包含特殊字符,例如!@#$%^&*()_+ 目前我有模式:(?!^[0-9]*$
我想检查密码是否至少包含一个字母和一个数字。接受特殊字符但不是必需的... 那将是一个简单的密码检查器。 最佳答案 您可以使用先行断言来检查任何数字和任何字母的存在,如下所示: ^(?=.*[a-zA
我需要找到生产至少三种不同型号电脑的制造商。结果集:制造商、型号数量。 我的 table 是产品(制造商、型号、类型)PC(代码、型号、速度、内存、高清、CD、价格) 我现在已经这样做了 SELECT
在我正在处理的哈希字典中,根据 GDB,数组的大小已从 500 调整到 1000。它在尝试添加时崩溃的数组索引是 799,所以它没有超出范围......我不是确定它为什么会出现段错误,尤其是在这样一条
我需要一个正则表达式来检查字符串的长度是否至少为 10 个字符。这些字符是什么并不重要。 谢谢 最佳答案 您可以使用: .{10,} 自 .默认情况下不匹配换行符,您必须使用合适的修饰符(如果您的正则
我有以下代码: val num1: Int? = someObject.number val num2: Int? = anotherObject?.anotherNumber val numToFa
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我一直在进行查询以获取用户列表及其各自的组。我知道了。 但是有一些限制: 如果用户只是 group5 的成员,则不应出现在列表中 如果是 group5 和其他组的成员,它应该出现在列表中 我可以获得不
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
我需要忽略任何一个空格,并且应该匹配至少大于一个空格的空格... "MARY HAD A LITTLE LAMB" 我希望 "MARY", "HAD A LITTLE", "
如何在仅数字验证中允许空格(至少 8 位数字)?当允许空格时,输入电话号码会更容易。例如0400 123 456、9699 1234。 到目前为止,这是我的代码,我只进行了最少 8 位数字验证: jQ
我想将以下内容重写为 HTML 模式: if (/\S/.test(myString)) { // string is not empty and not just whitespace }
我的想法是使用 php 或 js 创建大量的 div。 (我从昨天开始写js。) 所以我自己给定的任务是使用 php 或 js 或两者生成一个 div 网格。到目前为止的想法是有一个通用的 div 作
显示字符串中至少有 10 个数字字符的正则表达式。 可以多于 10 个,但不能少于 10 个。在随机位置可以有任意数量的其他字符,将数字分隔开。 示例数据: (123) 456-7890 123-45
我目前在 Firefox 中使用边框动画时遇到问题,从无到 50px。 Chrome 非常好,但 Firefox 不是,我想同样的问题也会出现在 Opera 中。 这里有一个 fiddle 来向您展示
作为 ruby 挑战训练的一部分,我被要求创建一个方法 substrings(string),它将接受一个字符串,并返回一个包含所有子字符串的数组。 即 substrings("cat") #=>
我目前有这段代码,它检查数组中的所有元素是否相同。如果是这种情况,则返回 true def all_equal(lst): """ >>> all_equal([1,1,1,1,1,1,1])
当我注意到 Libre Office 电子表格显示远低于 2^53 的数字的错误值时,我正在做一些计算以计划改进我的主要筛选器的实现,这是 FoxPro 和许多其他精确整数计算的限制内部使用 C do
我有一个复选框,我想检查用户是否填写了它后面的文本框。必须至少包含 5 个字符才能选中复选框。 pro)) echo 'checked' ?>> pro?>">Please supply your I
我正在为我的食谱设计一个数据库。我在我的设计中创建了多个表格:书籍、作者、食谱、成分,对于所有这些项目,我想将媒体(图像或视频)链接到所有这些表格中的项目。 我在想这样的设计: media_id, r
我是一名优秀的程序员,十分优秀!