Ruby版快速判素数算法

 

#encoding:utf-8
# 快速判定素数,用素数判定素数。比如求1-100之间的素数, 
# 先求1-10之间的素数为[2,3,5,7], 
# 再用11-100的数%[2,3,5,7],不能被整除的就是素数 

# 直接判定一个数是否为素数
def is_prime?(n)
	t = 2
	while (t <= Math.sqrt(n).to_i)
		if (n % t == 0)
			return false
		end
		t = t + 1
	end
	if n <= 1
		return false		
	end
	return true
end

def get_prime(n1,n2)
	result = [] # result用于保存begin-end之间的所有素数
	temp = []  # 保存2-Math.sqrt(end)之间的所有素数
	temp_index = 0
	result_index = 0
	for i in 2 .. Math.sqrt(n2).to_i
		if is_prime?(i)
			temp[temp_index] = i
			temp_index = temp_index + 1
		end
	end
	temp.each{|i|
		if i >= n1
			result[result_index] = i
			result_index = result_index + 1
		end
		# print i," "
	}
	# puts

	start =  Math.sqrt(n2).to_i
	if start > n1
		n1 = start
	end
	for i in n1 .. n2
		flag = true
		temp.each{|t|
			if i % t == 0
				flag = false
				break
			end
		}
		if flag
			result[result_index] = i
			result_index = result_index + 1
		end
	end
	return result
end

puts "请输入两个数并按回车键(格式为a b):"
while true
	num = gets.split(" ")
	n1 = num[0].to_i
	n2 = num[1].to_i
	result = get_prime(n1,n2)
	result.each{|i|
		print i," "
	}
	puts
end

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值