- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我在 StackOverflow 中遇到了 Euler 项目中问题 4 的许多解决方案。我的问题不是再次询问已经在 StackOverflow 中实现的项目 Euler 中问题 4 的解决方案。相反,我遇到了一个改进的解决方案 Improved solution by ROMANIA_engineer .我对改进的解决方案有两个问题。不管怎样,我已经在下面发布了解决方案,供人们研究。
public static void main(String[] args) {
int max = -1;
for ( int i = 999 ; i >= 100 ; i--) {
if ( max >= i*999 ) {
break;
}
for (int j = 999 ; j >= i ; j-- ) {
int p = i * j;
if ( max < p && isPalindrome(p) ) {
max = p;
}
}
}
System.out.println(max > -1? max : "No palindrome found");
}
问题
- Why there is a condition (max >= i * 999) ?. What are we going to achieve, by including such an inexpensive operation?
从下面的片段中,
for (int j = 999 ; j >= i ; j-- ) {
int p = i * j;
if ( max < p && isPalindrome(p) ) {
max = p;
}
}
- Instead of
j >= 100
, it is givenj >= i
. I can see a lot of time is saved, however, I wanted to know the intention behind it.
最佳答案
回答问题1,之所以有检查(max >= i * 999)
是因为你可能已经偶然发现了两个3位数的乘积是回文但大于 i * 999
。由于外部 for 循环从 i = 999 开始,一旦找到新的最大值,新的最大值可能大于下一次迭代中递减 i 值的最大可能回文乘积。例如,如果我们找到 926 * 998 的回文乘积,其中 i = 926 和 j = 998,并且新的最大值设置为该乘积。请注意,这只是一个假设,我什至不知道该产品是否是回文。然后内部for循环在迭代i = 926时结束。然后在外部for循环的下一次迭代中,i现在是925,并且由于925 * 999小于926 * 998,因此无需继续寻找最大回文产品,因为它已经被发现。原因是此时 925 * 999 是可以向前计算的最大可能回文乘积。
回答问题2,j>=i
的原因是为了避免乘积的重复计算。例如,假设条件是 j >= 100
。在内部 for 循环的第一次迭代中,当 j 为 999 且 i 也为 999 时。我们最终可能会计算从 999 * 999、999 * 998 到 999 * 100 的乘积。但是,如果内部for 循环曾经达到 i 现在是 100 并且 j 是 999 的点,那么你最终将重复计算 100 * 999。请注意,这只是一个示例,它甚至可能不会达到这一点。
关于java - 来自 Project euler 的问题 4 的改进解决方案,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54759104/
FogBugz 有没有办法创建一个过滤器,它是: [All] [open] [cases] assigned to [Developer A] with the exception of 1 or m
我是 java hibernate 的新手,我无法理解 Projections.property 和 Projections.groupProperty 之间的区别,两者都给出相同的结果。请解释其中的
让我们再试一次。我发布这个是为了回答 2 个问题 MS Project 2007 是否需要 SharePoint(我希望没有)? 做 你喜欢 MS Project 开发团队 - 它是有用的还是 疼痛?
我们的项目结构如下: sharedlib (lib-project, containing classes, that are useful in many apps) -> main-project
我正在尝试获取有关如何将 MS Project 2010 连接到 MS Project Server 2010 的教程或分步说明。 我已经在我的服务器上安装了 Server 2008 R2(64 位)
Projections.distinct(Projections.count("objectId")) 和 Projections.countDistinct("objectId") 谁能告诉我它们之
可以在项目 “project-a” 中创建一个主题“my-topic-project-a”,这样它就可以公开可见(已完成通过将角色“pub/sub subscriber” 设置为“allUsers”)
我创建了一个简单的 Kafka 消费者,它返回 Flux对象(收到的消息),我正在尝试使用 StepVerifier 对其进行测试. 在我的测试中,我做了这样的事情: Flux flux = cons
我有一个项目,最初是在 Eclipse 中,然后我设法将它转换为 gradle,并且在 Android Studio 中一切正常。 但后来我没有在这个项目上工作一段时间,几个月后当我回到项目时,我很惊
我正在研究 CQRS/ES 架构。我们将多个异步投影并行运行到读取存储中,因为某些投影可能比其他投影慢得多,并且我们希望与写入端保持更多同步以实现更快的投影。 我试图了解有关如何生成读取模型以及这可能
第一次尝试使用 Java 持久性注释创建多对多关系。 场景:Java 类Project 包含子项目,它只是Projects 的List。没有反向(没有 super 项目)成员。所以我认为多对多关系对于
我有现有的 C 代码和现有的 Makefile,我想将其包装到 Eclipse C 项目中(使用 Eclipse 3.4 Ganymede)。代码组织如下: 主目录:/Project/Software
我有一个 Eclipse 项目,不久前我设法在 Android Studio 中工作。它使用 TouchDB 库/项目,我现在想升级到他们最新的产品 couchbase-lite-android,看起
我将项目定义为包含主干、分支、标签子目录的 SVN 目录。 在确定何时将项目拆分为两个或将多个项目合并为一个时,您使用什么标准? - 每个“项目”一个应用程序,具有用于公共(public)源和资源的共
尝试在 Visual Studio 2008 中构建解决方案时遇到此错误。这是什么意思? 最佳答案 这可能意味着文件 bin\project.dll被另一个进程(可能是另一个 Visual Studi
此宏将隐藏/关闭 VBE 主窗口: Sub VBEMainWindowHide() 'close VBE window: Application.VBE.Window.Visible
我正在寻求开发户外应用程序,但不确定 tango 平板电脑是否可以在户外使用。那里的其他深度设备往往在室外效果不佳,因为它们依赖于从设备转换的红外光,然后在它从场景中的物体反射回来后进行观察。我一直在
在标准 .csproj您可以进入属性并设置默认命名空间。如何在 .xproj 中实现这一点项目使用 project.json ? 最佳答案 使用 ASP.NET Core 1.0.1,您可以在 pro
当 Redmine 上注册的项目超过 5 个时,主页“最新项目”框中列出的项目按创建日期降序排序(最近创建的优先),将旧项目(可能更新频率更高)排除在列表之外. 有没有办法按事件从最高到最低列出前 5
我开始学习android开发,但我不知道如何将库添加到项目中。我使用安卓工作室。我创建了新项目,但项目结构中没有项目设置。 最佳答案 在“项目”窗口中右键单击您的包名称,然后选择“打开模块设置”。这应
我是一名优秀的程序员,十分优秀!