随机生成一个n bit位的长整数。

来源:互联网 发布:差评拦截软件 编辑:程序博客网 时间:2024/05/22 08:15
 输入:随机数bit位的长度为n(解释:3bit位,则最大为111,最小为100;n bit位,则该数字二进制长度为n)
    输出:返回该随机数

由于随机生成的二进制数,最高位肯定是1,用math.pow(2,n-1)求得.其他位随机生成,用math.radom()函数求。
import java.util.Scanner;public class LongNum {public LongNum(){System.out.println("请输入一个指定二进制数的位数");Scanner scan = new Scanner(System.in);try{int input = scan.nextInt();System.out.println("随机生成的"+input+"二进制数转化long整数是");System.out.println(createNum(input));}catch(Exception e){System.out.println("输入错误,请重新输入正确的数");LongNum num = new LongNum();}}public long createNum(int n){//随机生成一个位的二进制数,最高位肯定是1,其他位随机生成,用random()函数随机生成long result  = (long)(Math.random()*Math.pow(2,n-1)+Math.pow(2,n-1));return result;}//主函数入口public static void main(String args[]){LongNum num = new LongNum();}}


0 0
原创粉丝点击