Generate Random Without Repeats
May 17, 2022 - by Bill Jelen
data:image/s3,"s3://crabby-images/11067/11067ca3da7c7d8880bad9dee50fb87c5999a51b" alt="Generate Random Without Repeats Generate Random Without Repeats"
Problem: I want Excel to generate numbers for the lottery. Once a number is chosen, I don’t want that number to appear again. Using RANDBETWEEN
, it is possible to get duplicates.
data:image/s3,"s3://crabby-images/4f5b0/4f5b03e8859c7e4c9ec2548caa2177d794eb58b3" alt="Using =RANDBETWEEN(1,56) in five cells. Press F9 enough times and you might get a repeat. The screen shows 42, 49, 39, 42, and 10."
Strategy: to solve this problem, you need to sort the 56 numbers into a sequence and choose the top five numbers from the list. This will prevent any duplicates from showing up.
Say that you want to generate five numbers from 1 to 56. Follow these steps:
1. Select a range that is one column wide by 56 rows tall.
-
2. Type
=RAND()
. Press Ctrl+Enter to enter that formula in all of the cells. In my example, I used A1:A56.
From here, you want to find the largest values using =LARGE(A1:A56,1)
then =LARGE(A1:A56,2)
, then LARGE(A1:A56,3)
, and so on. Once you locate the largest value, use MATCH
to find that value within the list. The position in the list represents the lotto number.
3. Combining all of those formulas together, you get
=MATCH(LARGE($A$1:$A$56,COLUMN(A1)),$A$1:$A$56,0)
. Enter this formula in C2:G2.4. For the extra ball, use a regular old
=RANDBETWEEN(1,46)
.
data:image/s3,"s3://crabby-images/b1841/b18417645dcb53caebe810c6702eac4415e3344b" alt="The formula uses MATCH, LARGE, and COLUMN to generate random numbers without repeats."
Additional Details: For PowerBall, enter numbers in A1:A59. Change the 56 in the formula above to a 59. Change the formula in H2 to get numbers from 1 to 39.
This article is an excerpt from Power Excel With MrExcel
Title photo by Herbert Goetsch on Unsplash