aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormarcandre <marcandre@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-10-20 03:18:14 +0000
committermarcandre <marcandre@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-10-20 03:18:14 +0000
commit1cca2e29eecd72652be3ac09aedc581f5e31456d (patch)
tree709a8edf857fe131be7da460823f8409fe5ce59e
parent34b2a6c3bf651e504146b25270f3a9e798ae47a1 (diff)
downloadruby-1cca2e29eecd72652be3ac09aedc581f5e31456d.tar.gz
* lib/prime.rb: Optimize Integer#prime?
Patch by Nick Slocum [Bug #10354] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@52200 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--lib/prime.rb9
2 files changed, 13 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 91e76ca9fb..1a16dc3509 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Tue Oct 20 12:17:50 2015 Marc-Andre Lafortune <ruby-core@marc-andre.ca>
+
+ * lib/prime.rb: Optimize Integer#prime?
+ Patch by Nick Slocum [Bug #10354]
+
Tue Oct 20 08:12:47 2015 Rei Odaira <Rei.Odaira@gmail.com>
* configure.in: pthread_getattr_np is broken on AIX.
diff --git a/lib/prime.rb b/lib/prime.rb
index c9575f6a2a..d99a51a967 100644
--- a/lib/prime.rb
+++ b/lib/prime.rb
@@ -31,7 +31,14 @@ class Integer
# Returns true if +self+ is a prime number, else returns false.
def prime?
- Prime.prime?(self)
+ 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
+ end
+ true
end
# Iterates the given block over all prime numbers.