- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
给定一个排序数组,其中包含一些序列号和一些非序列号。编写一个算法,将此数组作为输入并返回所有连续数字的 {start, end} 列表。连续数字仅相差 1。
例如数组:
[4, 5, 6, 7, 8, 9, 12, 15, 16, 17, 18, 20, 22, 23, 24, 27]
public class Range
{
private int begin;
private int end;
public int begin { get; set; }
public int end { get; set; }
}
这里的 O(n) 解决方案似乎很明显,但有没有办法在更短的时间内完成?
最佳答案
一个解决方案是一次说出 3 个数字并查看它们之间的差异
如果差值等于3那么它们是连续的,然后再向前移动3,直到你发现差值不是3,然后你向后移动一步,如果差值是2则结束范围并且从我们有差异的前一个数字开始您的下一个范围。
在最坏的情况下,根本没有连续的数字,对于大 N,我们将迭代 n/3 次,这很重要。
编辑:
这种方法最糟糕的情况是当有两个连续的数字对时,我们需要接触所有数字,所以在这种特殊情况下它将是 O(n)。
关于algorithm - 采访 : Find Ranges of All Consecutive Numbers,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27005791/
我正在将双引号 CSV 转换为 Unix 中的管道分隔 txt 文件。我使用以下 sed 命令将“,”替换为 |然后删除开始和结束双引号。 sed -e 's/","/|/g' -e 's/"//g'
我有一组数据,我需要计算它们的“连续平均值”(我不知道它是否是正确的名称,但我找不到更好的东西),这是一个例子: ID Var2 Var3 1 A 1 2 A 3 3
我目前正在尝试在用户发送消息或取消后,在短信(MFMessageComposeViewController)之后显示电子邮件 View (MFMailComposeViewController)..
题目地址:https://leetcode.com/problems/moving-stones-until-consecutive/ 题目描述 Three stones are on a num
题目地址:https://leetcode.com/problems/consecutive-numbers-sum/ 题目描述 Given a positive integer N, how m
想生成一列b来自 a以至于 if a == 1 then b = 0 else b = counting start from 1 then if a == 1 then b = 0 else b
我有以下 data.table(尽管如果您将它用作 data.frame 也没关系) library(data.table) dt dt first_column second_column
问题:我正在使用 Java,我正在尝试计算字符串中连续的“字符”。 示例: Scanner in = new Scanner(System.in); int n = in.nextInt(); Str
| RecordId | high_speed | speed | DateFrom | DateTo | --------------------------------
我正在尝试使用正则表达式解决问题。我正在使用 Java 正则表达式,它显然类似于 Perl 中的正则表达式。 我想搜索一个字符串,该字符串包含 1-9 中的单个数字,连续重复 3 次或更多次,或者在重
我想在 android 4.2 上按下按钮时连续更改图片此代码仅更改一次 代码: public void addListenerOnButton() { b1 = (Button) findV
开始使用 SPSS/Python,我需要对名称包含两个不同字符串的变量进行平均。我找到了很多单个字符串(或数字等)的示例,但我的字符串并不相邻。 var1_blabla_def_blabla_jkl
我想生成连续的 C++ 字符串,例如在相机中:IMG001、IMG002等能够指示前缀和字符串长度。 我找到了一个可以从具体字符集生成随机字符串的解决方案:link 但是我找不到我想要实现的东西。 最
这个问题不太可能帮助任何 future 的访客;它只与一个小地理区域、一个特定时刻或一个非常狭窄的情况相关,而这些情况通常不适用于互联网的全局受众。如需帮助使这个问题更广泛地适用,visit the
我的办公室大约有大约 300 个网页,应该定期对其进行测试。我在 Visual Studio 2010 中使用 Nunit、Selenium 和 C#。我使用了这个 framework作为基础,我确实
我在用户完成“锻炼”后保存核心数据,并希望能够检查用户锻炼的日期是否按连续顺序排列。我使用下面的代码来检查用户是否在日历上单击的一天进行了锻炼,但无法想象如何检查这些天是否连续。 起初我想获取保存的
我想让我的程序检查数组中任意两个连续的单词是否相同。我相信我的“if”语句是正确的,但是 console.log 显示所有连续的单词都匹配。我在这里想念什么? 感谢任何帮助!我是新手:) var wo
我有一个 Web 服务器,用于保存编号的 Web 应用程序的日志文件。文件名示例如下: dbsclog01s001.log dbsclog01s002.log dbsclog01s003.log 最后
小问题: 我有一个字符串: title="Announcing Elasticsearch.js For Node.js And The Browser" 我想找到每个单词正确大写的所有单词对。 因此
我有一个如下所示的数据框: Text Label a NaN b NaN c NaN 1 NaN 2 NaN b NaN c N
我是一名优秀的程序员,十分优秀!