- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我的目的是将多个字符串打成一个(最短的)字符串,该字符串将包含每个字符串的所有字符。这个问题并不特定于任何语言,而是更多地涉及到 algorithm
部分。 (可能会在 Node 服务器中实现它,所以标记 nodejs/javascript
)。
所以,解释一下问题:
假设我的字符串很少
["jack", "apple", "maven", "hold", "solid", "mark", "moon", "poor", "spark", "live"]
结果字符串应该是这样的:
"sjmachppoalidveonrk"
jack :sjmachppoalidveonrk
apple: sjmachppoalidveonrk
solid:sjmachppoalidveonrk
=====================================>>>> 全部向前
这些都是手动评估,示例中的输出可能不是 100% 完美。
所以,关键是每个字符串的所有字母都必须存在于输出中FORWARD DIRECTION(这里是实际问题所在),并且可能服务器将发送最终的字符串和像 27594
这样的数字将生成并传递以提取 token ,在所需的结尾。如果我必须用尽可能少的字符串打洞它会容易得多(这种情况只有唯一的字符就足够了)。但是在这种情况下有几点:
字母可以出现多次,但我必须重复使用任何字母字母如果可能,例如:对于 solid
和 hold
o > l > d
可以重用为正向,但用于 apple
(a > p
) 和 spark
(p > a
) 我们必须重复 a
,因为在一种情况下它出现在 p
之前对于 apple
,在 p
之后对于 sparks
所以我们需要重复a
或 p
。甚至,我们不能这样做 p > a > p
因为它不会涵盖这两种情况因为我们在 a
之后需要两个 p
用于 apple
我们直接没有选择放置单个 p
并使用相同的一次提取索引两次,我们需要多个 p
没有选项留下作为输入字符串包含该
我尝试过,从一个任意字符串开始,然后分析下一个字符串并拆分所有字母,并相应地放置它们,但是经过一段时间后,似乎可以将当前字符串字母放在更好的位置方式,如果根据当前字符串放置最后一个字符串(或前一个字符串)的字母。但是,该字符串再次根据已处理的内容(多个)进行分析和放置,并且将某些内容放置在未处理的内容上似乎很困难,因为我们需要处理它。或者我是否可以维护所有已处理/未处理树的树将有助于构建最终字符串?有什么比它更好的方法,它似乎是一个蛮力?
注意:我知道还有很多其他的转换可能,请尽量不要建议使用其他任何东西,我们正在研究它。
最佳答案
我想出了一个有点蛮力的方法。这种方式会找到组合 2 个单词的最佳方式,然后对数组中的每个元素进行组合。
此策略通过尝试找到将 2 个单词组合在一起的最佳方式来发挥作用。它被认为是最好的,因为它的字母最少。每个单词都被输入到一个不断增长的“合并”单词中。每次添加新词时,都会在现有词中搜索要合并的词中存在的匹配字符。一旦找到一个,就将它们分成两组并尝试加入(使用手头的规则,如果字母已经存在则不需要添加 2 等)。该策略通常会产生良好的效果。
join_word
方法需要两个你想加入的词,第一个参数被认为是你想加入另一个词的词。然后它搜索将 into
和 word
拆分为 2 个单独部分以合并在一起的最佳方法,它通过查找任何共享的公共(public)字符来做到这一点。这就是 splits_on_letter
方法的用武之地。
splits_on_letter
方法接受一个单词和一个您希望拆分的字母,然后返回一个二维数组,该数组包含该字符上所有可能的拆分左侧和右侧。例如 splits_on_letter('boom', 'o')
将返回 [["b","oom"],["bo","om"],["boo", "m"]]
,这就是我们如何使用字母o
作为分割点的所有组合。
开头的sort()
是试图将相似的元素放在一起。合并元素的顺序通常会影响结果长度。我尝试的一种方法是根据他们(与他们的同龄人)使用的常用字母的数量对它们进行排序,但结果各不相同。然而,在我所有的测试中,我可能有 5 或 6 个不同的单词集可供测试,如果使用更大、更多样化的单词数组,您可能会发现不同的结果。
输出是
spmjhooarckpplivden
var words = ["jack", "apple", "maven", "hold", "solid", "mark", "moon", "poor", "spark", "live"];
var result = minify_words(words);
document.write(result);
function minify_words(words) {
// Theres a good sorting method somewhere which can place this in an optimal order for combining them,
// hoever after quite a few attempts i couldnt get better than just a regular sort... so just use that
words = words.sort();
/*
Joins 2 words together ensuring each word has all its letters in the result left to right
*/
function join_word(into, word) {
var best = null;
// straight brute force each word down. Try to run a split on each letter and
for(var i=0;i<word.length;i++) {
var letter = word[i];
// split our 2 words into 2 segments on that pivot letter
var intoPartsArr = splits_on_letter(into, letter);
var wordPartsArr = splits_on_letter(word, letter);
for(var p1=0;p1<intoPartsArr.length;p1++) {
for(var p2=0;p2<wordPartsArr.length;p2++) {
var intoParts = intoPartsArr[p1], wordParts = wordPartsArr[p2];
// merge left and right and push them together
var result = add_letters(intoParts[0], wordParts[0]) + add_letters(intoParts[1], wordParts[1]);
if(!best || result.length <= best.length) {
best = result;
}
}
}
}
// its possible that there is no best, just tack the words together at that point
return best || (into + word);
}
/*
Splits a word at the index of the provided letter
*/
function splits_on_letter(word, letter) {
var ix, result = [], offset = 0;;
while((ix = word.indexOf(letter, offset)) !== -1) {
result.push([word.substring(0, ix), word.substring(ix, word.length)]);
offset = ix+1;
}
result.push([word.substring(0, offset), word.substring(offset, word.length)]);
return result;
}
/*
Adds letters to the word given our set of rules. Adds them starting left to right, will only add if the letter isnt found
*/
function add_letters(word, addl) {
var rIx = 0;
for (var i = 0; i < addl.length; i++) {
var foundIndex = word.indexOf(addl[i], rIx);
if (foundIndex == -1) {
word = word.substring(0, rIx) + addl[i] + word.substring(rIx, word.length);
rIx += addl[i].length;
} else {
rIx = foundIndex + addl[i].length;
}
}
return word;
}
// For each of our words, merge them together
var joinedWords = words[0];
for (var i = 1; i < words.length; i++) {
joinedWords = join_word(joinedWords, words[i]);
}
return joinedWords;
}
关于javascript - 将多个字符串打洞/组合成一个(可能最短的)字符串,其中包括每个字符串的所有字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45269325/
我正在尝试读取和处理一个大的 json 文件(~16G),但即使我通过指定 chunksize=500 读取小块,它仍然有内存错误。我的代码: i=0 header = True for chunk
请看下图... 我想通过 CSS 实现。 我现在将此分隔符用作在我的容器内响应的图像 ( jpg )。问题是我似乎无法准确匹配颜色或使白色晶莹剔透。 我认为 CSS 是解决这个问题的最佳方式。 尺寸为
所以我正在尝试使用 AngularJS 和 Node.js。我正在尝试设置客户端路由,但遇到一些问题。 编辑 所以我改变了一些代码如下 https://github.com/scotch-io/sta
我想创建如下图所示的边框: 这段代码是我写的 Some Text p{ -webkit-transform: perspective(158px) rotateX(338deg); -webk
好的,所以我有一个包含 2 个选项的选择表 $builder->add('type', 'choice', array( 'label' => 'User type', 'choice
我的代码: private void pictureBox1_MouseDown(object sender, MouseEventArgs e) { ngr.
我正在尝试编写 Tic-Tac-Toe 游戏代码,但不知道如何在轮到我时push_back '+' 字符。 因此,每当玩家输入例如“Oben 链接”时,这基本上意味着左上角,我希望游戏检查输入是否正确
我正在研究 HtmlHelper.AnonymousObjectToHtmlAttributes。 它适用于匿名对象: var test = new {@class = "aaa", placehol
在 stackoverflow 上所有这些 mod 重写主题之后,我仍然没有找到我的问题的答案。我有一个顶级站点,基本上我想做的就是将 /index.php?method=in&cat=Half+Li
仅使用 CSS 可以实现此功能区吗? 最佳答案 .box { width: 300px; height: 300px; background-color: #a0a0a0;
我有一个 jbuilder 模板,它用 json 表示我的一个模型,如下所示: json.(model, :id, :field1, :field2, :url) 如果我只是从控制台访问该字段,则 u
昨天我问了一个问题 - Draw arrow according to path 在那个问题中,我解释说我想在 onTouchEvent 的方向上绘制一个箭头。我在评论中得到了答案,说我应该旋转 Ca
我希望段落中的代码与代码块中显示的代码一致。 例如: The formula method for a linear model is lm(y~x, data = dat). For our da
我使用 ViewPager 获得了一个选项卡菜单。每个选项卡都包含来自 android.support.v4 包的 fragment (与旧 SDK 的兼容性)。其中一个 fragment 是 Web
我正在从事一项需要多种程序能力的科学项目。在四处寻找可用的工具后,我决定使用 Boost 库,它为我提供了 C++ 标准库不提供的所需功能,例如日期/时间管理等。 我的项目是一组命令行,用于处理来自旧
外媒 Windows Latest 报道,随着 Windows 10 的不断发展,某些功能会随着新功能的更新而被抛弃或成为可选项。早在 2018 年,微软就确认截图工具将消失,现代的 “截图和草图”
我有标记的 Angular ,我只希望标记旋转到那个 Angular 。 marker = new google.maps.Marker({ position: myL
我一定是遗漏了什么,但我不知道是什么。我有使用 polymer 实现的简单自定义元素: TECK ..
我有一个关于如何设置我们产品的分步教程。我必须在每个步骤中显示大量示例代码。以下是我必须在页面中显示的代码类型列表。我用什么来格式化所有内容? Java 代码示例 XML 样本 iOS SDK 文件(
我需要在我的 iPad 应用程序中绘制一些图表,所以我遵循了本教程: http://recycled-parts.blogspot.com/2011/07/setting-up-coreplot-in
我是一名优秀的程序员,十分优秀!