动手动脑,产生随机数
1、 程序設計思路
產生不重復的多個隨機數,設置一個初始數,運用公式X(n+1)=(x(n)*a+c)%mod。
X(n)為初始數,a,c為系統自己賦值的數,都是值比較小的數,而mod必須是一個大數,由于取余數,所以mod必須足夠大才能使隨機數不重復。
2、 程序流程圖
?
3、源代碼
package java作業;
import java.util.Scanner;
public class suijishu
{
public static void main(String args[])
{
Scanner sc=new Scanner(System.in);
System.out.println("產生多少個隨機數:");
int shumu;
shumu=sc.nextInt();
int a=2;
int chushi=1;
int c=3;
int[] chuan=new int[shumu];
for(int ha=0;ha<shumu;ha++)
{
chuan[ha]=(chushi*a+c)%(999999999);
chushi=(chushi*a+c)%(999999999);
}
for(int ha=0;ha<shumu;ha++)
{
System.out.print("第"+(ha+1)+"個隨機數字為:");
System.out.println(chuan[ha]);
}
}
}
4、程序截圖
?
轉載于:https://www.cnblogs.com/CHAHA123/p/7664247.html
總結
以上是生活随笔為你收集整理的动手动脑,产生随机数的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: BZOJ 1012: [JSOI2008
- 下一篇: HDU 5792 World is Ex