给定一个任意字符串的文本,任务是将文本分组为模板的不同部分。每个部分具有不同的最小长度和最大长度参数。只要一个解决方案落在这些范围内,就可以认为解决方案是最优的。贪婪的解决方案可能会导致某些部分达不到最低要求,这意味着解决方案作为一个整体是不可接受的。文本分组算法
我很难有效地构造一个算法来做到这一点。似乎动态编程方法可能会有所帮助,但到目前为止,我还没有能够用动态编程术语来解决它。有没有人有解决这个问题的任何线索?
function groupText(str, template)
Inputs:
str: a string of text
template: array of JavaScript objects.
One object per section that describes the min/max amount of text allowed
Output:
array: each element corresponds to one section.
The value of the element is the text that is in the section.
作为一个例子,让我们定义一个字符串str,它等于“这是一个测试”。我们也有一个模板t。 t由几个部分组成。每个部分s具有允许的最小字符数和最大字符数。假设这个例子只有两个部分:s1和s2。 S1具有最小1个字符的和最大的100 S2具有最小的10个字符,最多15。我们通过我们的字符串STR和我们的模板吨到功能groupText。 groupText必须返回一个数组,其中每个元素对应于一个段。例如,元素0将对应于s1。元素的值将是已分配给该部分的文本。
在这个例子中,一个解决方案可能是。
s1text = “此”
s2text = “是一个测试”。
你想要做的一个例子会帮助我们更好地理解你的问题。尤其是输入和期望输出的一个例子。 – 2012-03-14 19:43:31
这听起来像是一个线性编程问题。 – mindvirus 2012-03-14 19:54:06
@HighPerformanceMark - 我已经添加了一个例子。让我知道这是否有帮助。感谢您的反馈。 – tabdulla 2012-03-14 19:57:21