- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有以下任务要解决:
Given a page of content with alphanumeric words, and a search phrase of N words, write an algorithm that will return the shortest snippet of content that contains all N words in any order.
这就是我目前所拥有的。我把页面上的文字放到一个没有标点符号的数组中:
var allText = $('#all-text').text();
var punctuationless = allText.replace(/[^A-Za-z0-9_]/g," ").toLowerCase();
var lessSpaces = punctuationless.replace(/\s{2,}/g," ");
var allTextArray = lessSpaces.split(" ");
var keywords = [];
我想我或许可以使用 .filter 方法,但我不确定如何比较两个数组。
allTextArray.filter(keywords)
//find the indexes of the matches to the keywords
//compare how far apart the indexes are to each other and return the shortest length
最佳答案
因此,根据我对 OP 的理解列出一些示例,如果页面文本是:
One for the money,
two for the show.
“One”、“money”
应该生成 “One for the money”
。"One","two","for"
应该生成 "One for the money, two"
搜索词 "for","show"
应该生成 "for the show"
为了钱,两个为了表演
我添加最后一点是因为这就是这样一个函数变得非常复杂的地方,因为它现在必须找到所有组合中尺寸最小的搜索词组合。
我解决了 a jsfiddle solution 对此,但我不会声称这是最有效的答案(因为已经很晚了,我的部分思想可能已经休眠)。
基本上,这是一个迭代和提前扫描的解决方案,这可能是人们用眼球做的方式:
总而言之,检查所有可能的片段,包括所有关键字。
重要的是要注意,我创建的解决方案不区分大小写,它匹配单词的一部分,而不是整个单词,并且 OP 暗示不区分大小写和整个单词匹配。
不区分大小写(将所有输入文本转换为小写)和全词匹配(去除标点符号和多余空格的文本,然后拆分为数组)的策略应该很容易适用于该解决方案,特别是因为 indexOf
对字符串和数组的作用相同。
getSnippet = function(keywords, fullText) {
var keywordCount = keywords.length,
keywordIndexes = [];
// Find each occurrence of every word
for(var i=0; i < keywordCount; i++) {
var searchPos = 0;
var word = keywords[i];
var index = -1;
do {
index = fullText.indexOf(keywords[i],searchPos);
if (index >= 0) {
keywordIndexes.push({i:index, word:word});
}
searchPos = index + 1;
} while (index >= 0);
}
keywordIndexes.sort(function(a, b) { return a.i == b.i ? 0 : a.i < b.i ? -1 : 1; });
// Find the shortest run by starting at each array index and scanning to the
// right until we have encountered each word in the list.
for (i=0, n=keywordIndexes.length-keywordCount; i<=n; i++) {
// NOTE: We actually can actually stop once there are fewer keyword
// indexes than keywords, since we know we won't find all the keywords (hence the subtraction of keywordCount)
var foundWords = {},
foundCount = 0;
snippetStart = keywordIndexes[i].i;
for (j=i; j < keywordIndexes.length; j++) {
var word = keywordIndexes[j].word;
if (!foundWords[word]) {
foundWords[word] = true;
foundCount++;
}
if (foundCount == keywordCount) {
// We've found all the words
snippetEnd = keywordIndexes[j].i + word.length;
if (minSnippet.end - minSnippet.start > snippetEnd - snippetStart) {
minSnippet.end = snippetEnd;
minSnippet.start = snippetStart;
}
break;
}
}
}
return fullText.substring(minSnippet.start, minSnippet.end);
}
参见 jsfiddle 了解更多信息。
关于javascript - 如何从关键字搜索中返回最短的片段?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35514156/
如果我创建一个对象时没有使用 new 关键字,例如“Object s(someval)”,但该对象的构造函数使用了 new,当该对象超出范围时,是否会调用析构函数为其分配新的空间?我感觉好像是,但我不
在 SQL 语法中,我发现奇怪的规则表明 select * from ONLY (t1)是有效的 SQL。 我的问题是:什么是 ONLY在这种情况下是什么意思? 它在规范的“7.6 table ref
为什么使用 $(this) 而不是重新选择类很重要? 我在代码中使用了大量的动画和 CSS 编辑,并且我知道可以使用 $(this) 来简化它。 最佳答案 当您通过 jQuery 执行 DOM 查询(
我正在尝试使用 IN 关键字编写查询。 表A 属性标识、属性名称 表B key 、属性标识、属性值 根据提供的 key ,我想返回所有 attrName、attrVal 组合。结果将包含两个表中的列。
这个问题在这里已经有了答案: Why would you use "AS" when aliasing a SQL table? (8 个答案) 关闭 9 年前。 我不擅长写查询,但是从我开始使用
我读过,在 Java 中,您不必将 this 关键字显式绑定(bind)到对象,它由解释器完成。它与 Javascript 相反,在 Javascript 中你总是必须知道 this 的值。但是 Ja
Swift 中“with”关键字的用途是什么?到目前为止,我发现如果您需要覆盖现有的全局函数,例如 toDebugString,可以使用该关键字。 // without "with" you
这个问题在这里已经有了答案: What does the keyword "where" in a class declaration do? (7 个答案) 关闭 9 年前。 在下面的一段代码中(
免责声明:swift 菜鸟 您好,我刚刚开始学习 Swift,正在学习 Swift 编程语言(Apple 在 WWDC 期间发布的书籍),并且想知道“where”关键字是什么。它用于 let vege
深入研究文档后,我找不到以下问题的答案: 是否有任何理由反对使用 this 来引用当前对象,如下例所示? type MyStruct struct { someField string } fun
前言 最近在做THINKPHP开发项目中,用到了 parent:: 关键字,实际上 parent::关键字 是PHP中常要用到的一个功能,这不仅仅是在 THINKPHP 项目开发中,即使是一个小型
我们都知道且经常用到 unsigned 关键字,但有没有想过,与此对应的 signed 关键字有啥用? 复制代码 代码如下: int i = 0; signed
this关键字再java里面是一个我认为非常不好理解的概念,:)也许是太笨的原因 this 关键字的含义:可为以调用了其方法的那个对象生成相应的句柄。 怎么理解这段话呢? thinking i
一 什么是 synchronized synchronized 关键字提供了一种锁机制,能够确保共享变量互斥访问,从而防止数据不一致问题的出现。 synchronized 关键字包括 monitor
最近看了几篇 synchronized 关键字的相关文章,收获很大,想着总结一下该关键字的相关内容。 1、synchronized 的作用 原子性:所谓原子性就是指一个操作或者多个操作,要么全部执行并
在本教程中,您将借助示例了解 JavaScript 对象方法和 this 关键字。 在 JavaScript 中,对象也可以包含函数。例如, // object containing meth
有人可以解释一下 PHP“with”的作用吗? 示例开始: 假设我有一个类: \App\fa_batch 这句话有什么区别: $w = (with (new \App\fa_batch))
这个问题在这里已经有了答案: What is the difference between using the colon and as syntax for declaring type? (2
如果我在 WHERE 子句中使用以下任一项,是否会有很大不同: WHERE [Process Code] = 1 AND ([Material ID] = 'PLT' OR [Material ID]
This question is unlikely to help any future visitors; it is only relevant to a small geographic are
我是一名优秀的程序员,十分优秀!