Ruby测试小代码[计算50以内的素数]

算法思想

判断某一个数,能不能被比他平方根小的素数整除。

首先看看代码

$arr = []
$arr[0] = 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(","),"\n"

分析一下

  • 关于变量:$xxx是创建全局变量
  • 3.step(n,2){}:就是从3开始,每次加2得到的数,比如1.step(10, 2) { |i| print i," " } 结果就是 1 3 5 7 9
  • ruby if判断的时候,比较另类, action if condition,所以return false if number % $arr[j] == 0的意思是 如果对$arr[j]取余为零,则返回false
  • 输出的时候,","起到连接符的作用,"aaa","bbb"其实就是aaabbb
  • 输出可以用puts或者print,puts就是比print多了自动回车而已

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏码农分享

2、苏宁百万级商品爬取 思路讲解 类别页数爬取

这种方法是为了单独解决这个问题而使用的,很笨拙,因为如果只有200个类别,多线程的意义就没有办法体现出来,这一点在之后的编码中我进行了修改。

15020
来自专栏牛肉圆粉不加葱

揭开Spark Streaming神秘面纱④ - job 的提交与执行

前文揭开Spark Streaming神秘面纱③ - 动态生成 job 我们分析了 JobScheduler 是如何动态为每个 batch生成 jobs,本文...

8030
来自专栏mathor

LeetCode130. 被围绕的区域

 bfs题,主函数中枚举每一个起点,如果是'O'就开始bfs搜索,首先将'O'变为'X',然后将周围是'O'都入队。这里有个地方要注意,如果'O'并不是被...

10620
来自专栏数据结构与算法

Day6上午解题

预计分数:100+100+30=230 实际分数:90+25+10=125 T1少判了一种情况,T2的贪心是错的,T3被卡了。。。 T1 模拟水题,注意20的可...

33450
来自专栏C/C++基础

Linux命令(12)——wc命令

(3)从文件读取输入文件名。如果有多个文件名,并且希望 wc 从一个文件中读取它们,那么使用-files0-from 选项。这里将文件名称必须以NULL字符结束...

11610
来自专栏菩提树下的杨过

DateTime在ExtJs中无法正确序列化的问题

这几天在学习ExtJs + Wcf的过程中,发现一个问题,如果Class中有成员的类型为DateTime,即使我们正常标识了[DataMember],序列化成J...

214100
来自专栏云霄雨霁

范式总结

15640
来自专栏游戏杂谈

Unity Inspector面板常用的属性

其它还有诸如 HelpURL 等,详情可参考 官方帮忙文档 https://docs.unity3d.com/ScriptReference/HeaderAtt...

31030
来自专栏菩提树下的杨过

VisualTreeHelper

Silverlight中只有可视化树,没有WPF中的逻辑树,这一点可从SL的sdk文档中得到印证: 可视化树概念也存在于 WPF 中,它与 Silverligh...

23770
来自专栏WOLFRAM

交互式查询化学键信息

25930

扫码关注云+社区

领取腾讯云代金券