- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在重新尝试这个 problem statement , now that the contest is all over (所以这不是作弊或任何东西,只是想学习,因为答案没有公布,只有给定测试用例输入文件的正确输出)。
有 10 个给定的测试用例输入,将为其提交相关的输出文件。我最初提交的是一个简单的嵌套 for 循环(开始,结束)对的实现,回答了这个问题:What is the volatility measure of the substring starting at (0-based) index start
, and结束于end
(含)。
很明显,对于 106 的最大问题限制,O(N2) 是不可行的,所以我只有 5/10 个测试用例是正确的(第一个 - 更简单 - 当然是 5)。
因此,我在这里写信是为了寻求关于如何改进我的算法的人群智慧,即我怀疑嵌套的 for 循环(开始,结束)是优化的主要瓶颈(当然!)所以到目前为止,我已经尝试将其表述为关于字符串/子字符串问题的动态规划 (DP),但在提出状态表示和转换位以实现 DP 方面没有取得太大成功。
为了方便引用,也为了表明这不是作业,我已经诚实地尝试过了,我的原始提交可用here .
非常感谢任何帮助,甚至是指向类似问题的链接,我可以通过谷歌搜索这些问题以获取教程博客文章/示例解决方案/赛后编辑分析。
最佳答案
你尝试过分而治之吗?
如果我理解正确的话,给定一条长度为 n 的 DNA 链 S,我们将 S 分成两半,S_left 和 S_right,其中 S_left 由 S[i] 组成,其中 0 <= i < n/2,和 S_right由 S[j] 组成,其中 (n/2)+1 <= j < n。最不稳定的片段要么完全出现在 S_left 内,要么完全出现在 S_right 内,或者跨越 S_left 和 S_right 的边界。
要找到 S_left 和 S_right 中最不稳定的片段,我们只需使用递归。棘手的一点是找到跨越 S_left 和 S_right 边界的片段的波动率度量。这里有一个正整数分数的数学性质:给定四个正(非零)整数 a、b、c 和 d,(a + c)/(b + d) 永远不会大于两者 (a/b) 和 (c/d)。这里 a 和 b 是 S_left 中从边界开始的嘌呤和嘧啶的累积计数,而 c 和 d 是从边界开始的 S_right 中嘌呤和嘧啶的累积计数。这个数学属性意味着我们不需要检查 a = 0 或 c = 0 之外的交叉片段的波动率度量,因为它保证小于 S_left 或 S_right 的最大波动率。这种搜索的时间复杂度可以在交叉片段的 O(n) 和整个算法的 O(n lg n) 中完成。
希望这有效,因为我还没有编写算法代码。也许它有一个 O(n) 时间的 DP 算法来解决这个问题,但这就是我现在所拥有的。
关于algorithm - Marathon24 比赛资格 : DNA -TLE,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19524747/
我正在为客户构建一个简单的 Django 应用程序,它允许用户注册付费帐户以访问网站的某些部分;但是,除了几个简单的 Paypal 按钮之外,我从未处理过付款处理。 我的问题是,在这种情况下我该如何安
根据 ISO C 标准 (6.3.16.1),如果“两个操作数都是指向兼容类型的合格或非合格版本的指针,并且左边指向的类型具有所有右边指向的类型的限定符”。我在我的静态分析工具中收到了警告,但我不确定
我用 paypal 创建了 2 个订阅按钮。此按钮适用于不同的成员(member)资格:1. 基本 2. 专业。我正在尝试使用此按钮订阅成员(member)资格并且工作没有任何问题。但是当我试图通过其
如果我想做一个管理功能,比如删除 asp.net mvc 示例附带的 asp.net 成员(member)资格内容中的用户。 我尝试查看表格,发现有多个表格添加了行。我想一定有一个更简单的方法。 最佳
我希望在新网站上创建博客和论坛。我希望用户注册后可以在论坛上发帖,在博客上发表评论,并拥有自己的公共(public)个人资料页面。 我有使用 BlogEngine.NET 的经验,所以希望使用它。我目
我对 MVC 和使用 ASP.NET MVC 4 开发应用程序还很陌生。对于身份验证,我在域中使用 Windows 身份验证和 Active Directory。下一步是授权用户(不使用成员(memb
我试图找出用户第一次使用asp.net 成员(member)资格(mysql)登录,并根据它显示一些协议(protocol)页面。我遵循的程序是: When a user registers a ma
我最近刚刚研究出如何使用 PayPal IPN 在用户支付一定金额后启动高级成员(member)资格。一旦用户点击升级帐户,他们就会被定向到 PayPal 进行支付,然后 IPN 就会启动更新数据库以
我正在尝试学习 Java 中的继承和接口(interface)。我有三个不同的类:Customer、SilverCustomer 和 GoldCustomer。 SilverCustomer 和 Go
我刚刚收到一封来自 Apple 开发者门户的电子邮件(2 月 20 日),说我需要续订我的成员(member)资格。当我查看我的帐户时,我的订阅实际上在 4 月 20 日用完。我的问题是,如果我现在续
要向 iOS 应用程序添加推送通知,您是否需要拥有已注册 iOS 成员(member)计划的苹果开发者帐户? 最佳答案 Yes , it is - see the terms here 看这里- In
protected void Button2_Click(object sender, System.EventArgs e) //logout { if (System.Web.HttpCo
我正在构建一个使用蓝牙与远程传感器通信的 iPhone 应用程序。外设是蓝牙自行车速度传感器。该应用程序使用来自外围设备的信息来计算行驶距离。 我看到有一个蓝牙特别兴趣小组 (SIG) 负责确保制造商
我正在使用 asp.net mvc 示例应用程序,并对其进行了一些扩展。我使用 asp.net 成员(member)身份进行用户登录和注册。 我现在想更改它,以便当人们注册时,它不会立即能够登录,而是
我为我的客户创建了一个成员(member)登录系统,现在他们不希望用户在创建新密码时使用他最后 5 个密码之一。 这是内置的东西吗?我怎样才能实现它? 最佳答案 asp.net 成员(member)登
我正在为一个公共(public)站点开发 ASP.NET4.0/C# 应用程序,该应用程序仅需要对在关联企业工作的员工进行身份验证。这个想法是让网站拥有一个 CMS,以便员工可以进入并更改某些内容,而
如何通过 ID 获取用户?MembershipUser mu=Membership.GetUser("用户名");但是,我想通过 ID 获取用户,而不是通过名称获取用户。 最佳答案 Membershi
是否可以让用户拥有多个资格之一才能从事 HIT。例如: qualifications = Qualifications() qualifications.add( Requirement(co
现在我们有几个数据库,每个数据库都有自己的 aspnet 成员表。我们希望将所有成员集中到一个数据库中。例如一个主登录页面,他们将在其中指定数据库、用户名和密码。然后我们将检查集中式数据库并根据他们在
我正在使用 Paypal 的定期成员(member)付款。我想知道是否有成员(member)手动从paypal取消成员(member)资格,我如何从paypal获取返回值/URL,以便我可以跟踪成员(
我是一名优秀的程序员,十分优秀!