jjzjj

Algorithm

全部标签

ruby - 背包 : how to add item type to existing solution

我一直在使用动态规划的这种变体来解决背包问题:KnapsackItem=Struct.new(:name,:cost,:value)KnapsackProblem=Struct.new(:items,:max_cost)defdynamic_programming_knapsack(problem)num_items=problem.items.sizeitems=problem.itemsmax_cost=problem.max_costcost_matrix=zeros(num_items,max_cost+1)num_items.timesdo|i|(max_cost+1).ti

ruby - 将 10 进制数转换为 N 进制数的算法

我正在寻找一种方法将以10为基数的数字转换为以N为基数的数字,其中N可以很大。具体来说,我正在考虑转换为base-85,然后再转换回来。有谁知道执行转换的简单算法?理想情况下,它会提供如下内容:to_radix(83992,85)->[11,53,12]欢迎任何想法!罗亚 最佳答案 这是一个有趣的问题,所以我有点过火了:classIntegerdefto_base(base=10)return[0]ifzero?raiseArgumentError,'basemustbegreaterthanzero'unlessbase>0num

ruby - Ruby 中用于 "String#include?"的算法

有谁能指出包含的算法是什么?Ruby中的方法?例如"helloworld".include?("hello") 最佳答案 正如emboss在他的回答中所述,String#include调用rb_str_index。此函数依次调用rb_memsearch,它实现了Rabin-Karpstringsearchalgorithm,根据thispost在ruby-forum.com上。 关于ruby-Ruby中用于"String#include?"的算法,我们在StackOverflow上找到一

ruby - 邻接表和图

我正在尝试通过邻接列表构建一个图,这意味着我需要一个包含所有节点的列表,并且在每个节点类中,我还需要一个数据结构来保存所有相邻节点。只是想知道执行此操作的最佳结构是什么(快速搜索目标节点类)。数组行得通吗? 最佳答案 这是在Ruby中构建有向图的一种方法,其中每个节点都维护对其后继节点的引用,但可以通过名称引用节点。首先,我们需要一个节点类:classNodeattr_reader:namedefinitialize(name)@name=name@successors=[]enddefadd_edge(successor)@suc

ruby - 选择一个随机选项,其中每个选项被选中的概率不同

假设给您三个“选项”,A、B和C。您的算法必须随机选择并返回一个。为此,只需将它们放在一个数组{A,B,C}中并生成一个随机数(0、1或2),这将是元素在返回数组。现在,这个算法有一个变体:假设A有40%的机会被选中,B有20%,而C40%。如果是这种情况,您可以采用类似的方法:生成一个数组{A,A,B,C,C}并生成一个随机数(0,1,2,3,4)选择要返回的元素。行得通。但是,我觉得效率很低。想象一下,将此算法用于大量选项。你会创建一个有点大的数组,可能有100个元素,每个元素代表1%。现在,这仍然不是很大,但假设您的算法每秒使用多次,这可能会很麻烦。我考虑过创建一个名为Slot的

ruby-on-rails - 解析 'ul' 和 'ol' 标签

我必须处理ul、ol和li标签的深层嵌套。我需要提供与我们在浏览器中提供的View相同的View。我想在pdf文件中实现以下示例:text="OneTwoInnerOneinnerTwoheyhiiiiiiiiiwhyhiiiiiiiiianiketsupthereheyThreeIntroductionIntroductionDescriptionObservationResultsSummaryIntroductionDescriptionObservationResultsSummaryOverview"我必须用虾来完成我的任务。但是大虾不支持HTML标签。所以,我想出了一个使用

ruby - ruby 中的机器学习算法

我正在关注StanfordMachineLearningclass与教授。AndrewNg和我想开始用ruby​​实现示例。是否有任何框架/gems/libs/现有代码可以在ruby​​中实现机器学习?我发现了一些与此和一些项目相关的问题,但似乎已经很老了。 最佳答案 算法本身不是特定于语言的。您可以使用任何您想要的语言来实现它们。为了获得最大效率,您将需要使用基于矩阵/向量的计算。Ruby有一个内置的Matrixclass可以用来实现这些算法。该实现与使用Octave的实现非常相似。您自己实现算法所需的一切都包含在1.9+的基本标

ruby - 查找两个单词之间的相邻单词列表

我正在应对一项编程实践挑战,但在寻找用于实现解决方案的良好数据结构/算法时遇到了困难。背景:如果您可以通过添加、删除或更改单个字母将一个词更改为另一个词,则将两个词称为“相邻”。“单词列表”是唯一单词的有序列表,其中连续的单词是相邻的。问题:编写一个程序,将两个单词作为输入并遍历字典并在它们之间创建一个单词列表。示例:hate→love:hate,have,hove,lovedogs→wolves:dogs,does,doles,soles,solves,wolvesman→woman:man,ran,roan,roman,womanflour→flower:flour,lour,do

Ruby 字谜求解器

关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭6年前。Improvethisquestion我想用Ruby编写一个anagram类型的求解器,但它可以处理单词列表,就像这样。单词列表是:thetheseoneowner我会允许用户输入一些字母,例如noe,它会在单词列表中搜索它可以使用用户输入的字母组成的单词,然后返回one,如果他们输入“eth”甚至“the”,它会带回the。我一直在想一个有效的方法来做到这一点,但我一直在循环每个单词,匹配单词中的一个字母,检查每个字母的单词和两个长

ruby - 有效地处理数字数组的 "scale"或 "resize"的算法(音频重采样)

做音频处理(虽然它也可以是图像处理)我有一个一维数字数组。(它们恰好是代表音频样本的16位有符号整数,这个问题同样适用于float或不同大小的整数。)为了匹配不同频率的音频(例如,将44.1kHz样本与22kHz样本混合),我需要拉伸(stretch)或压缩值数组以满足特定长度。将数组减半很简单:每隔一个样本丢弃一次。[231,8143,16341,2000,-9352,...]=>[231,16341,-9352,...]将数组宽度加倍稍微不那么简单:将每个条目加倍(或可选地在相邻的“真实”样本之间执行一些插值)。[231,8143,16341,2000,-9352,...]=>[2