在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
虽然ruby/ruby on rails从2007年就一直获奖无数,但身为一个中国人,一直对小日本创造的东西不怎么感兴趣,想想其实也没必要,技术本身是无国界的,日本其实也有值得学习的地方(扯远了,呵) using System; namespace Mersenne { class Program { static void Main(string[] args) { for (int i = 2; i < 50; i++) { if (CheckDigital(i)) { Console.WriteLine("{0} ",i); } } Console.ReadLine(); } static bool CheckDigital(int i) { if (i <= 1) { return false; } if (i == 2) { return true; } bool _result = true; for (int j = 2; j < i; j++) { if (i % j == 0) { _result = false; break; } } return _result; } } } 参照这个思路,翻译成ruby版: for i in 2..100 flag = true; for j in 2...i if i % j==0 flag = false; break; end end if flag print i,"\n" end end
利用ruby语法的灵活性,可以精简成以下代码: for i in 2..100 flag = true; (2...i).each{|n| flag=false if i % n ==0} print i,"\n" if flag end
def checkNum?(num) return true if num==2 f = true; for j in 2...num if num % j==0 f = false; break end end return f end (2..50).each{|x| print x,"\n" if checkNum?(x)} 另外一种实现: $arr=[] #定义一个全局数组,用来保存计算结果 $arr[0] = 2 #定义方法,将n以内的奇素数加入$arr (素数同时肯定奇数,2除外) def add_prime(n) 3.step(n,2){|num| $arr<<num if is_prime? num} end #定义方法 判断是否为素数 def is_prime?(number) j=0 while $arr[j] * $arr[j] <=number return false if number % $arr[j] ==0 j +=1 end return true end add_prime(50); #调用 puts $arr.join(',') #输出结果 |
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论