- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
首先,这不是作业:我在 CodeEval 上提交了一些 Java 代码。
挑战归结为以下问题:
Start with a number n. If it's a palindrome, stop. Otherwise, reverse the digits of n, add them to n, and repeat this process. Report how many steps are necessary before the number converges to a palindrome.
一点都不难。此外,在我提交代码并获得 100% 的挑战后,我开始再次查看我的代码 - 我想确定我的递归调用方法的时间复杂度以及在递归方法中调用我的方法。
其中,我想到了:
//adds the i'th integer in String[] data to its reversed integer:
private final int add(int x)
{
//if x is 0, then don't do anymore computation
if(x==0)
{
count++;
return x;
}
//if x equals its reversal, the palindrome has been found
if(x==rev(x))
{
return x;
}
//keep adding and reversing
else
{
//if MAX has been reached, STOP
if (count==MAX)
return 0;
//increment the count
count++;
_intTmp=rev(x); //get the reversal
return add(x + _intTmp); //recursive call: keep adding
}//else:end
} //Main::add() end
所以...我计算了 T(N): 1 + log(1/n)
//reverse the integer: worst case is O(N)
private final int rev(int orig)
{
int reversed=0;
while(orig>0)
{
//adds the last digit from orig to reversed
reversed=reversed*10+orig%10;
orig=orig/10; //gets rid of the last digit
}
return reversed; //return the reversed integer
}//Main::final end
我计算了:O(N)
此代码片段的总体时间复杂度为:O(1+log(1/n)+n) ~ O(N)
我是对的,还是我哪里搞砸了?
感谢您的宝贵时间和建议...
最佳答案
我认为没有人知道这个函数的大 O 运行时是什么,或者它是否有大 O 运行时。挑战暗示某些数字最终是否以这种方式形成回文是未知的。事实上,这是数学中的一个悬而未决的问题;这样的数字称为 Lychrel number没有人知道它们是否存在!
如果存在多个这种形式,您的算法在其上运行时将进入无限循环,因此该输入的运行时间将没有上限。另一方面,如果不存在这种形式的数字,则运行时限制将取决于您必须将数字的倒数与其自身相加以形成回文的总次数。
但是,现在,让我们假设所需的迭代次数是有限的。假设对于任何数字 n,都有一个数字 f(n) 告诉您必须使用数字反转和相加技巧的次数。请注意,每次反转数字并相加时,数字最多增加 9 倍。添加 d 位数字需要时间 O(d),反转 d 位数字也需要时间 O(d)。另外,请注意数字 n 中有 O(log n) 位数字。因此,运行时将是
log n + 9 log n + 92 log n + ... + 9f(n) log n
= O(9f(n) log n)
因此,如果确实存在必要步骤数的上限 f(n),则运行时间将为 O(9f(n) log n)。
我不确定您如何将 O(1 + 1/log n) 作为主要步骤的运行时间。如果您提供更多有关您如何得出这一点的详细信息,我可以尝试帮助您更详细地检查您的逻辑。
希望这对您有所帮助!
关于java - 反向然后添加序列 : Big-O runtime of my solution?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23729406/
我在内存中有一个 Map 来存储我的对象。我想在内存不足时刷新内存。我现在正在这样做: void add(K key, V value) { if (underPressure()) {
我是 JBPM 的新手。我下载并开始使用 eclipse。然后我安装了 JBPM 插件和 Modeler 2.0 插件。当我创建一个新的 JBPM 项目时,它要求 JBPM 运行时。我在互联网上搜索了
我是 JBPM 的新手。我下载并开始使用 eclipse。然后我安装了 JBPM 插件和 Modeler 2.0 插件。当我创建一个新的 JBPM 项目时,它要求 JBPM 运行时。我在互联网上搜索了
我目前正在将Windows 8.1应用程序移植到Windows 10 UAP应用程序,该应用程序使用互操作在C++和C#之间进行通信,并且 pop 以下错误: $(ProjectName).Inter
我正在使用 Parcel 来捆绑我的项目并 Jest 运行我的测试。 一切正常,但在测试中我有 async/await关键字,我必须导入 regenerator-runtime/runtime像这样:
一旦我尝试使用 Promises,Browserify 就会抛出此错误。 在 中找不到模块“regenerator-runtime/runtime” 我尝试过 Node 版本 10.15.3 和 12
我目前正在试验 quarkus,找不到在运行时更改一些 openapi 信息的方法(这里,我希望授权 url 根据环境而改变)。 应该可以通过使用 OASFilter 并从环境变量中提供信息来实现,但
我正在使用 rust_bert 汇总文本。我需要使用rust_bert::pipelines::summarization::SummarizationModel::new设置模型,该模型可以从互联网
我正在 Visual Studio 中处理其中一个新的“类库(NuGet 包)”项目。一切都很顺利,直到前几天它开始引发有关 System.Runtime.Extensions 程序集的错误: Ass
我正在使用 tokio::runtime::current_thread::Runtime我希望能够在同一个线程中运行 future 并停止 react 堆。页面上的示例未显示如何停止运行时。有什么办
我找不到如何声明 runtime.LockOSThread()和 runtime.UnlockOSThread() .我将其定义为 [runtime.LockOSThread()] 一些代码 [run
我有这样的代码, Routine 1 { runtime.LockOSThread() print something send int to routine 2 runtime.UnlockOSTh
我正在尝试执行此操作:当我单击“搜索”按钮时,命令提示符窗口打开。 我尝试使用ProcessBuilder,没有出现错误,但是不起作用。你能帮我一下吗? package sys.tool; impor
我的应用程序运行大约 4 小时后出现此错误。我不知道为什么会这样。该错误发生在 windows 7 和 windows XP 系统上。抱歉,我没有更多信息。我的应用程序运行大约 4 次后才收到此错误消
我收到错误:“此程序集是由比当前加载的运行时更新的运行时构建的,无法加载。” 我有一个 .NET 2.0 项目调用的 .NET 4.0 dll 项目。有没有办法调和框架的差异? 最佳答案 I have
我有一个 WIX 安装程序,它在安装过程中执行自定义操作。当我运行 WIX 安装程序并遇到它的第一个自定义操作时,安装程序失败,我在 MSI 日志中收到如下错误: Action start 12:
我正在尝试提交 spark 作业 它是这样开始的: import javax.xml.parsers.{SAXParser, SAXParserFactory} import org.apache.s
我正在做一些 WCF 工作,但我不明白为什么会遇到这个错误。 System.Runtime.Serialization.DataContractAttribute命名空间中不存在 System.Run
我尝试按照 this 在 React 应用程序中使用 async/await : 目前,我正在运行webpack --config webpack.dev.config.js --watch --pr
我已经从托管的 Window Server 2008 下载了已发布的(代码隐藏文件不存在,与 bin 文件夹中的 dll 结合)Web 应用程序,并在调试该应用程序时使用 Visual Studio
我是一名优秀的程序员,十分优秀!