2

我正在使用 Ruby 2.4。如何检查数组中至少 80% 的元素是否与某个模式匹配?我想看看每个元素是否与正则表达式匹配

/\d\d?\s*-\s*\d\d?/
4

3 回答 3

2

您可以将Enumerable#grep与简单的数学结合使用:

array.grep(/\d\d?\s*-\s*\d\d?/).size / array.size.to_f >= 0.8

要进一步缩短此时间,您可以使用Numeric#quoNumeric#fdiv

array.grep(/\d\d?\s*-\s*\d\d?/).size.quo(array.size) >= 0.8
于 2017-01-09T16:47:47.420 回答
1

如果性能确实很重要,您无需检查所有元素以了解是否至少 80% 的元素符合条件

使用 ruby​​ 2.3 这个实现比 count 解决方案快一点,比 grep 解决方案快两倍:

def pareto_match(array, proportion: 0.8)
  min_success= (array.count * proportion).round(4)
  max_failures= (array.count * (1 - proportion)).round(4)
  success= 0
  failure= 0
  array.each do |element|
    if yield(element)
      success+= 1
      return true if success >= min_success
    else
      failure+= 1
      return false if failure > max_failures
    end
  end
end

pareto_match(array){|e| e =~ /\d\d?\s*-\s*\d\d?/}
于 2017-01-09T22:40:44.010 回答
0

我会写:

(array.count{|item| item =~ /\d\d?\s*-\s*\d\d?/} / array.size) >= 0.8
于 2017-01-09T19:26:18.640 回答