做一个积极的人

编码、改bug、提升自己

我有一个乐园,面向编程,春暖花开!

在未来城市工作的的程序员小木,做了一个梦,梦到自己在塔鲁姆的街道上看到一个姑娘,这个姑娘从远处走向他,脸上带着微笑。让小木很是着迷,小木呆呆的望着姑娘从他身边走过,当他回过神来,发现姑娘已经走远,小木赶忙去追这位姑娘,突然天空中飘下一张字条,上面写着:

我一眼就看出你是Java程序员了,当你能用代码实现 520~1314 之间的随机整数,那么我会主动来找你的!

小木还很纳闷,为什么这个姑娘知道自己是一个程序员,姑娘难道是上天专门派来的吗 ?

小木同学,见下图:

小木很兴奋啊,终于我学的Java编程有用武之处了,这个比写CRUD和看项目留下的烂代码好很多啊,我写好了,姑娘就来找我了。小木大脑开始快速运转,脑神经之间相互发送消息,收集储存起来的数据。

几秒之后,小木想到了一个方法,在刚开始学习Java的时候学过一个 Math 类,它里面有一个生成随机数的方法random()。但是通过Math.random() 获取的随机数是[0,1)之间的double值。注:包含0,但1不包含!

那要获取整数,则需要将上面的结果转行成int类型即可。获取[0, 1)之间的int整数。方法如下:

double d = Math.random();
// [0, 1)
int love = (int) (d);
// randNumber 将被赋值为一个 MIN 和 MAX 范围内的随机数
int randNumber = rand.nextInt(MAX - MIN + 1) + MIN;

简单思考:要让值落在520~1314,那么

MAX : 1314

MIN: 520

因为 Math.random() 获取[0, 1),换算公式: (Math.random() * (MAX - MIN)) + MIN

根据公式照葫芦画瓢,小木很快就实现随机 520~1314 的代码了!

 double d = Math.random();
// [520, 1314)
int love = (int) (d * (1314-520)) + 520;

写完上面的代码后,小木想还是要检查检查,不能马虎大意,毕竟这关乎姑娘会不会来找自己。代码运行N多遍之后,520是包含了,但是1314 怎么也出现不了!小木很快意识到这问题很严重。没有1314 姑娘找他这件事肯定就泡汤了。重新看上面的换算公式, 小木发现公式有点问题,少了个 1 啊!

正确的公式是 : (Math.random() * (MAX - MIN + 1)) + MIN

 double d = Math.random();
// [520, 1315)
int love = (int) (d * (1314 - 520 + 1) + 520;

这样就完美一点了,随机数就可以包含1314,这样就可以[520,1314]了。

注: 为了方便阅读,括号内就没有直接写出运算后的值。

大脑还处在高速运转的小木,实现了上面的功能后,心想这么容易就能约到姑娘了,这是不是有点太简单了。于是又想还有没有其他办法还能实现此功能呢?又想到了有Math.random()。不是还有一个Random类嘛,和Random类一起的还有一个ThreadLocalRandom类。不管咋,我在用一种方法实现以下,好好表现一下自己也好!

使用Random获取[520, 1314]之间的int整数,Random 对象的nextInt(int) 方法,将生成 [0, int)之间随机取值的整数。根据上面的思路,实现代码如下:

Random random = new Random();
// [520,1315) == [520,1314]
int love = (random.nextInt(1314 - 520 + 1) + 520);

小木在上面代码下面备注了如下内容:

1、Random类采用AtomicLong实现,保证多线程的线程安全性,但是多线程并发获取随机数时性能较差。

2、ThreadLocalRandom就实现了,ThreadLocalRandom继承了Random。多线程环境中可以使用ThreadLocalRandom作为随机数生成器,ThreadLocalRandom采用了线程局部变量来改善性能。

最后当小木写完代码后,听到早晨的闹钟响了,美梦就这样被闹钟无情的敲碎了,醒来后,小木久久不能忘记梦中的姑娘,想着什么时候能够再次偶遇!

你期待小木和梦中姑娘的的再次相遇嘛,我真的还期待,说不定一段美妙的爱情火花就会擦出。

原文 用Java实现在【520,1314】之间生成随机整数的故事

用Java实现在【520,1314】之间生成随机整数的故事的更多相关文章

  1. 明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性,他先用计算机生成了N个1到1000之间的随机整数(N≤1000),对于其中重复的数字,只保留一个,把其余相同的数去掉,不同的数对应着不同的学生的学号。然后再把这些数从

    明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性,他先用计算机生成了N个1到1000之间的随机整数(N≤1000),对于其中重复的数字,只保留一个,把其余相同的数去掉,不同的数对应着不同的 ...

  2. 页面上有3个输入框:分别为max,min,num;三个按钮:分别为生成,排序,去重;在输入框输入三个数字后,先点击生成按钮,生成一个数组长度为num,值为max到min之间的随机整数点击排序,对当前数组进行排序,点击去重,对当前数组进行去重。 每次点击之后使结果显示在控制台

    <!DOCTYPE html> <html> <head> <!-- 页面上有3个输入框:分别为max,min,num:三个按钮:分别为生成,排序,去重: 在 ...

  3. 获取m,n之间的随机整数

    获取m,n之间的随机整数 代码去下:

  4. JS中,输出1-10之间的随机整数

    <script> document.write(parseInt(10*Math.random())); //输出0-10之间的随机整数 document.write(Math.floor ...

  5. python生成随机整数

    python生成随机不重复的整数,用random中的sample index = random.sample(range(0,10),10) 上面是生成不重复的10个从1~10的整数 python生成 ...

  6. python中生成随机整数(random模块)

    1.从一个序列中随机选取一个元素返回:   random.choice(sep)    2.用于将一个列表中的元素打乱   random.shuffle(sep)    3.在sep列表中随机选取k个 ...

  7. 要生成在[min,max]之间的随机整数,

    import java.util.Random; public class RandomTest { public static void main(String[] args) { int max= ...

  8. java生成随机整数

    1. 使用Random类的nextInt方法: Random rand = new Random(); rand.nextInt(max);, 此时输出[0,max),注意右边是开区间,如果需要设定最 ...

  9. js 取任意两个数之间的随机整数

    function getRandomInt(min, max) { min = Math.ceil(min); max = Math.floor(max); return Math.floor(Mat ...

随机推荐

  1. linux netlink套接字实现相似ss命令 ,统计套接字以及TCP信息

    參考了 ss的源码 以及 netlink相关资料:http://blog.csdn.net/scdxmoe/article/details/27711205 实现结果为: gcc netlink_di ...

  2. 让你完全理解base64是怎么回事

    HTTP将BASE64-编码用于基本认证和摘要认证,在几种HTTP扩展中也使用了该编码. Base-64编码保证了二进制数据的安全 Base-64编码可以将任意一组字节转换为较长的常见文本字符序列,从 ...

  3. for in、for和EnumerateObjectsUsingBlock遍历的区别

    1.对于集合中对象数很多的情况下,for in 的遍历速度非常之快,但小规模的遍历并不明显(还没普通for循环快) 2. 如果在for in 循环里,对这个数组进行了修改的话,无论是增,删,修改数组元 ...

  4. android application类简单介绍(一)

    每次应用程序执行时.应用程序的application类保持实例化的状态. 通过扩展applicaiton类,能够完毕下面3项工作: 1.对android执行时广播的应用程序级事件如低低内做出响应. 2 ...

  5. Servlet之中文乱码问题【入门版】

    请求数据的中文问题 1 post请求提交中文 get请求建议不提交中文(只是也有方法解决) 1.1post request.setCharacterEncoding("utf-8" ...

  6. Redis开源项目的终极杀手? ——CRUG解读Redis开源协议变更

    引言: 数据库制造商 Redis Labs 本周将公司开发的Redis 模块从 AGPL 迁移到将 Apache v2.0 与 Commons Clause 相结合的许可证,对许可证涵盖的软件作了限制 ...

  7. hdu 5256 序列变换

    最长上升子序列 nlogn;也是从别人的博客学来的 #include<iostream> #include<algorithm> #define maxn 100000+5 u ...

  8. docker映射端口与ssh访问或容器访问

    映射端口 -d 后台执行 -p映射端口 --privileged 可以使用systemctl # docker run --privileged -d -p 9000:80 jiqing9006/ce ...

  9. pip 清华镜像

    临时使用: 可以在使用pip的时候加参数-i  https://pypi.tuna.tsinghua.edu.cn/simple 例:pip install -i https://pypi.tuna. ...

  10. MySQL:MySQL安装

    ylbtech-MySQL:MySQL安装 mysql5.5.27_win64_zol.msi 1.返回顶部 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14 ...