1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00

* lib/prime.rb: Optimize prime?

Adapted from patch by Jabari Zakiya [#12665]

* test/test_prime.rb: Improve test

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@55856 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
marcandre 2016-08-10 18:17:41 +00:00
parent 3433653240
commit 2401c512ef
3 changed files with 20 additions and 15 deletions

View file

@ -1,3 +1,10 @@
Thu Aug 11 03:16:59 2016 Marc-Andre Lafortune <ruby-core@marc-andre.ca>
* lib/prime.rb: Optimize prime?
Adapted from patch by Jabari Zakiya [#12665]
* test/test_prime.rb: Improve test
Wed Aug 10 22:37:01 2016 Nobuyoshi Nakada <nobu@ruby-lang.org>
* parse.y (command_rhs, arg_rhs): introduce new rules to reduce

View file

@ -33,11 +33,12 @@ class Integer
# Returns true if +self+ is a prime number, else returns false.
def prime?
return self >= 2 if self <= 3
return false if self % 2 == 0 or self % 3 == 0
(5..(self**0.5).floor).step(6).each do |i|
if self % i == 0 || self % (i + 2) == 0
return false
end
return true if self == 5
return false unless 30.gcd(self) == 1
(7..Math.sqrt(self).to_i).step(30) do |p|
return false if
self%(p) == 0 || self%(p+4) == 0 || self%(p+6) == 0 || self%(p+10) == 0 ||
self%(p+12) == 0 || self%(p+16) == 0 || self%(p+22) == 0 || self%(p+24) == 0
end
true
end

View file

@ -140,17 +140,14 @@ class TestPrime < Test::Unit::TestCase
end
def test_prime?
# zero and unit
assert_not_predicate(0, :prime?)
assert_not_predicate(1, :prime?)
PRIMES.each do |p|
assert_predicate(p, :prime?)
end
# small primes
assert_predicate(2, :prime?)
assert_predicate(3, :prime?)
# squared prime
assert_not_predicate(4, :prime?)
assert_not_predicate(9, :prime?)
composites = (0..PRIMES.last).to_a - PRIMES
composites.each do |c|
assert_not_predicate(c, :prime?)
end
# mersenne numbers
assert_predicate((2**31-1), :prime?)