excel如何随机生成不重复整数?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了excel如何随机生成不重复整数?相关的知识,希望对你有一定的参考价值。
不使用宏
1、首先在excel表格中输入随机函数公式:=rand()。
2、点击回车并下拉公式即可得到一组随机函数,先将该组随机函数复制粘贴为数值,将其固定显示在单元格中。
3、然后再其右侧的空白单元格中输入公式:=RANK($B$3:$B$12,$B$3:$B$12)。
4、点击回车并下拉公式即可得到一组不重复的随机整数。
参考技术A1、新建Excel,在E列输入学号,在D2单元格输入函数 =RAND(),该函数会返回一个0~1的小数,按Enter。
2、鼠标点击上述生成的随机数,指针放置单元格右下角,变成+号时,拖动鼠标至D31单元格。
3、此时D列形成的30个随机数如下
4、选择F2:F31单元格,在编辑栏中输入公式 =RANK(D2:D31,D3:D31),按Ctrl+Shift+Enter键进行确认。
5、F列生成的30个随机整数如下所示,没有重复的。
6、若看着D列不太舒服,可以将其隐藏,效果如下。随便点击一个空白格,按Delete键,可更新这30个整数的顺序。
参考技术B利用一个辅助列比如C3到C12,在C3输入公式:=rand()向下拉到C12,然后在B3利用排序函数得到1~10的不重复数字,B3输入公式:=RANK(C3,$C$3:$C$12)向下拉到B12。如果你觉得C列碍眼,可以把C列隐藏,也可以先复制B列,再在B列选择性粘贴/数值/确定,就可以把C列删除了。
把辅助列建在其他工作表,比如在Sheet2的C3(也可以其他单元格,但后面公式要相应更改)输入公式:=rand()向下拉到C12,然后在你的表格Sheet1的B3输入公式:=RANK(Sheet2!C3,Sheet2!$C$3:$C$12)向下拉到B12。
公式法:
我们以生成1-10范围内的随机数字为例,讲述方法。 首先,在A2单元格中输入公式:=SMALL(IF(COUNTIF($A$1:A1,ROW($1:$11))=0,ROW($1:$11)),INT(RAND()*(11-ROW(A1))+1)) 然后按下Ctrl+Shift+Enter三键结束数组公式;
然后,下拉填充公式到A12单元格,也就是填充11个单元格,为什么要填充11个呢,我们明明只要10个数字?这是因为,最后一个数字是不会变化的,所以呢,要生成10个随机数,需要填充11个单元格,同样的生成11个随机数的话,要填充12个单元格,除此之外,公式中的11还要改成12。
生成随机数后,每按下一次F9(或者其他单元格进行一次计算),随机数就会刷新一次,重新生成一组随机;
Small函数的第二个参数,也就是从这个序列中取第几个最小值,在得到的数字中,利用随机函数rand和row函数,实现在这有个个数中随机抽取一个数字,从而得到排序中这个数字顺序的一个数字。通过这样一个数组公式,就实现了生成一组不重复的随机数字。
1、选择A1:A100单元格,输入=RAND() 按Ctrl+Enter组合键结束;
2、选择B1:B100单元格,输入=RANK(A1,A:A) 按Ctrl+Enter组合键结束,生成100个不重复的随机整数。
详见附图
实用的随机数生成类Random:测试(随机产生100个不重复的正整数)
实用的随机数生成类Random:测试(使用Random类随机生成100个不重复的正整数)
一、之前我们使用随机数用的是Math类的random()方法:
tips:
产生随机数(0~9中任意整数)的方法:int random = (int)(Math.random()*10);
1.商场幸运抽奖程序。
会员号的百位数字等于产生的随机数即为幸运会员。
public class GoodLuck{
public static void main(String[] args){
//产生随机数
int random = (int)(Math.random()*10);
//从控制台接收一个4位会员号
System.out.println("我行我素购物管理系统>幸运抽奖\n");
System.out.print("请输入4位会员号:");
Scanner input = new Scanner(System.in);
int custNo = input.nextInt();
//分解获得百位
int baiwei = custNo/100%10;
//判断是否是会员
if(baiwei = random){
System.out.println(custNo+"是幸运客户,获精美MP3一个。");
}else{
System.out.println(custNo+"谢谢您的支持!");
}
}
}
二、其实,Math类的random方法的底层就是使用Random类实现的。
1.给构造方法有两种重载方法:
Random();
创建一个新的随机数生成器。
Random(long seed);
使用单个long种子创建一个新的随机数生成器。
tips:
如果用同样一个种子值来初始化两个Random对象,然后用每个对象调用相同的方法,那么得到的随机数也是相同的(令牌)
2.返回下一个伪随机数的方法:
int nextInt();
返回下一个伪随机数,它是此随机数生成器的序列中均匀分布的int值。
int nextInt(int n);
返回下一个伪随机数,它是取自此随机数生成器序列的,在0(包括)和指定值(不包括)之间均匀分布的int值。
三、Random类的使用
1.随机生成20个10以内大于或等于0的整数,并将其显示出来:
import java.util.Random;
public class RandomDemo{
public static void main(String[] args){
//创建一个Random对象
Random rand = new Random();
//随机生成20个随机整数,并显示
for(){
int num = rand.nextInt(10);
System.out.println("第"+(i+1)+"个随机数是:"+num);
}
}
}
2.案例:随机产生100个不重复的整数
import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Calendar; import java.util.Date; import java.util.HashSet; import java.util.List; import java.util.Random; import java.util.Set; /** * 随机生成100个不重复的随机数 * @author Administrator * */ public class RandomDemo { public static void main(String[] args) throws ParseException { Random rand = new Random(); System.out.println("Set方法:"); //Set集合保存 Set<Integer> nums = new HashSet<Integer>(); //循环保存 do{ nums.add(rand.nextInt(100)); }while(nums.size()<100); for (Integer num : nums) { System.out.println(num); } System.out.println("List方法:"); //List集合保存 List<Integer> list = new ArrayList<Integer>(); int num; do{ num = rand.nextInt(100); for (Integer item : list) { if (num==item) { continue; } } list.add(num); }while(list.size()<100); for (Integer item : list) { System.out.println(item); } /*Date类的使用*/ //日期格式 Date date = new Date(); SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日 24小时HH:mm:ss 12小时hh:mm:ss"); SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd"); System.out.println("当前时间:"+sdf.format(date)); String str = "2016-12-31"; Calendar calendar = Calendar.getInstance(); date = sdf1.parse(str); calendar.setTime(date); System.out.println(calendar.get(Calendar.YEAR)); } }
以上是关于excel如何随机生成不重复整数?的主要内容,如果未能解决你的问题,请参考以下文章