时间:2021-05-22
单从技术而言,ruby本身确实很爽,令程序员的工作变得轻松有趣!
下面的代码演示了如何找出100以内的素数:
复制代码 代码如下:
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(',') #输出结果
作者:菩提树下的杨过
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
jQuery学习笔记:jQuery学习1、基本语法:$(selector).action()$:定义jQueryselector:选择符,查询和查找HTML元素
前言初识go语言不到半年,我是一次偶然的机会认识了golang这门语言,看到他简洁的语法风格和强大的语言特性,瞬间有了学习他的兴趣最近学习Go,但是苦于没有项目
Ruby中的循环用于执行相同的代码块指定的次数。本章将详细介绍Ruby支持的循环语句。Rubywhile语句:语法:whileconditional[do]co
Ruby中的循环用于执行相同的代码块若干次。本章节将详细介绍Ruby支持的所有循环语句。Rubywhile语句语法whileconditional[do]cod
语法:ruby-align:auto|left|center|right|distribute-letter|distribute-space|line-edg