- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
大家好,这是一个关于散列的 Java 练习。首先我们有一个包含 N 个字符串的数组 (1<=N<=100000),程序将找到包含原始数组中所有不同字符串的连续子序列的最小长度。
例如原数组为{apple,orange,orange pear,pear apple,pear}
连续的子数组可以是{orange, pear, pear, apple}
所以答案是19
我编写了一段代码,它访问数组中的每个元素并创建一个新的哈希表来查找包含所有不同字符串的子数组的长度。一旦 N 大于 1000,它就会变得非常非常慢。所以我希望有一个更快的算法。谢谢!
最佳答案
遍历数组一次,使用散列来跟踪您之前是否看过某个单词。仅当您第一次看到一个词时,通过添加计数来计算数组中不同的词。
第二次遍历数组,使用散列来跟踪您看到每个单词的次数。还要跟踪您看到的所有单词的长度总和。继续前进,直到您至少看过所有单词一次。
现在,在不将单词计数减少到零的情况下尽可能向前移动范围的开头。请记住相应地调整您的散列和字母数。这为您提供了第一个范围,其中每个单词至少包含一次,并且在不排除单词的情况下无法减少。
重复执行以下操作:将范围的左端向前移动一个,然后将右端向前移动,直到找到刚刚从左端启动的单词的另一个实例。每次执行此操作时,您都会有另一个最小范围,其中包含每个单词一次。
在执行第 3 步和第 4 步时,跟踪到目前为止的最小长度,以及相关范围的开始和结束。当您需要将范围的右端移动到数组末尾之后时,您就完成了。此时,您拥有正确的最小长度,以及实现它的范围。
这在线性时间内运行。
关于java - 使用散列法查找总长度最小的字符串子数组,该子数组包含原始数组中的所有不同字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19926168/
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 6年前关闭。 Improve this qu
我有实体: @Entity @Table(name = "CARDS") public class Card { @ManyToOne @JoinColumn(name = "PERSON_I
我正在尝试计算二维多边形的表面法线。我正在使用 OpenGL wiki 中的 Newell 方法来计算表面法线。 https://www.opengl.org/wiki/Calculating_a_S
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 关闭 7 年前。 Improve
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 9 年前。 Improve this
我这里有以下 XML: Visa, Mastercard, , , , 0, Discover, American Express siteonly, Buyer Pay
即将发生的 Google 政策变更迫使我们实现一个对话框,以通知欧盟用户有关 Cookie/设备标识符用于广告和分析的情况。我只想向欧盟用户显示此对话框。我不想使用额外的权限(例如 android.p
本文分享自华为云社区《华为大咖说 | 企业应用AI大模型的“道、法、术” ——道:认知篇》,作者:华为云PaaS服务小智。 本期核心观点 上车:AGI是未来5~10年内,每个人都无法回避的技
我有一个与酒精相关的网站,需要先验证年龄,然后才能让他们进入该网站。我使用 HttpModule 来执行此操作,该模块检查 cookie,如果未设置,我会将它们重定向到验证页面。我验证他们的年龄并存储
在欧盟,我们有一项法律,要求网页请求存储 cookie 的许可。我们大多数人都了解 cookie 并同意它们,但仍然被迫在任何地方明确接受它们。所以我计划编写这个附加组件(ff & chrome),它
以下在 C 和/或 C++ 中是否合法? void fn(); inline void fn() { /*Do something here*/ } 让我担心的是,第一个声明看起来暗示函数将被定义
我是一名优秀的程序员,十分优秀!