我一直在思考以下问题-有两个数组,我需要找到它们不常见的元素,例如:a=[1,2,3,4]b=[1,2,4]预期的答案是[3]。到目前为止,我一直这样做:a.select{|elem|!b.include?(elem)}但它给了我O(N**2)时间复杂度。我相信它可以更快地完成;)此外,我一直在考虑以这种方式获取它(使用一些与&相反的方法,它给出了2个数组的公共(public)元素):a!&b#=>doesn'tworkofcourse另一种方法可能是将两个数组相加并使用类似于uniq的方法找到唯一元素,这样:[1,1,2,2,3,4,4].some_method#=>wouldret
我有一个数组,还有一个数组,其中包含第一个数组中某些元素的索引。从第一个数组中获取元素的最佳方法是什么?我在做:result=[]indexes.each{|current|result但应该有更好的方法.. 最佳答案 您可以使用Array#map:indexes.map{|i|my_array[i]}或者更好,Array#values_atmy_array.values_at(*indexes)*符号将数组提取到传递给方法的参数中。 关于Ruby通过索引访问多个数组元素(子数组),我们
我想制作一个具有大小参数的View助手(例如func(size))。问题是这个大小必须在函数中用作符号。例如,如果我将'medium'传入func,我需要将其转换为:medium。我该怎么做? 最佳答案 有很多方法可以做到这一点:如果你的字符串没有空格,你可以简单地这样做:"medium".to_sym=>:medium如果你的字符串有空格,你应该这样做:"mediumthing".gsub(/\s+/,"_").downcase.to_sym=>:medium_thing或者如果您使用的是Rails:"mediumthing".p
在使用Nokogiri(Rubygem)解析HTML页面期间,我如何检查页面上是否存在元素(在本例中为div)?在我的测试页面上,它确实存在,因此pp会产生预期的Nokogiri输出。但是if语句不起作用,==true似乎是错误的方法。有什么改进建议吗?干杯,克里斯pppage.at('.//div[@class="errorMsg"]')ifpage.at('.//div[@class="errorMsg"]')==truethenputs"Errormessagefoundonpage"end 最佳答案 与true比较不是正确的
我有一个对象数组[,,]我需要数组按时间排序,然后按值排序[,,]但是使用sort_by会抛出错误,因为时间为零。我现在正在使用一种丑陋的方式进行排序,但我相信有一个很好的方式来解决这个问题starred=[]@answers.each{|a|(starred 最佳答案 starred.sort_by{|a|[a?1:0,a]}当它必须比较两个元素时,它会比较一个数组。当Ruby比较数组(调用===方法)时,它比较第一个元素,只有当第一个元素相等时才转到第二个元素。?1:0保证,我们将Fixnum作为第一个元素,所以它应该没有错误。
我需要一种非常快速的方法来确定数组是否仅由值为9的整数组成。这是我目前的解决方案:input=[9,9,9,9,9,9,9,9,9,9,9,9]input.uniq==[9]你能做得更快吗? 最佳答案 require'benchmark'n=50000Benchmark.bmdo|x|x.report"uniq"don.timesdoinput=[9,9,9,9,9,9,9,9,9,9,9,9]input.uniq==[9]endendx.report"delete"don.timesdoinput=[9,9,9,9,9,9,9,9
有什么办法可以更优雅地重写这个吗?我认为,这是一段糟糕的代码,应该重构。>>a=[2,4,10,1,13]=>[2,4,10,1,13]>>index_of_minimal_value_in_array=a.index(a.min)=>3 最佳答案 我相信这只会遍历数组一次并且仍然很容易阅读:numbers=[20,30,40,50,10]#=>[20,30,40,50,10]elem,idx=numbers.each_with_index.min#=>[10,4] 关于Ruby:如何找
我需要一个返回/打印整数符号的函数。到目前为止,我想出了这个:defextract_sign(integer)integer>=0?'+':'-'end是否有内置的Ruby方法可以做到这一点? 最佳答案 这里有一个简单的方法:x=-3"++-"[x0]#=>"-"x=0"++-"[x0]#=>"+"x=3"++-"[x0]#=>"+"或x=-3"±+-"[x0]#=>"-"x=0"±+-"[x0]#=>"±"x=3"±+-"[x0]#=>"+" 关于ruby-如何在Ruby中提取整数的符
我的问题是使用正则表达式从字符串中删除表情符号,而不是从字符串中删除CJK(中文、日文、韩文)字符。我尝试使用这个正则表达式:REGEX=/[^\u1F600-\u1F6FF\s]/i这个正则表达式工作正常,除了它还可以检测我需要的中文、日文和韩文字符。知道如何解决这个问题吗? 最佳答案 KarolS已提供asolution,但原因可能不清楚:"\u1F600"实际上是"\u1F60"后跟"0":"\u1F60"#=>"ὠ""\u1F600"#=>"ὠ0"对于FFFF以上的代码点,您必须使用花括号:"\u{1F600}"#=>"?"
我正在学习each如何在ruby中工作的细节,我尝试了以下代码行:p[1,2,3,4,5].each{|element|el}结果是一个数组[1,2,3,4,5]但我不认为我完全理解为什么。为什么each的返回值是同一个数组?每个人不只是提供一种迭代方法吗?或者只是each方法返回原始值的常见做法? 最佳答案 Array#each返回调用它的[array]对象:block的结果是discarded。因此,如果原始数组没有icky副作用,那么什么都不会改变。也许你的意思是使用map?p[1,2,3,4,5].map{|i|i*i}