- 세상의 모든 계산기 수학, 과학, 공학 이야기 확률통계 ()
[확률] - 6/45 로또를 5게임을 선택 했을 때, 당첨 번호 6개 하나도 안맞을 확률은?
1. 게임간 숫자 중복 선택을 허용하지 않을 때
문제 요약
- 45개의 번호 중 6개가 1등 번호입니다.
- 5게임을 중복 없이 선택하면 총 30개의 번호가 선택됩니다.
- 이 30개 번호 중에 1등 번호가 하나도 포함되지 않을 확률을 구하려고 합니다.
접근 방식
1. **총 경우의 수:**
- 45개 숫자 중 30개를 선택하는 경우의 수는 \(\binom{45}{30}\)입니다.
2. **바람직하지 않은 경우의 수:**
- 1등 번호 6개를 제외한 39개 숫자 중 30개를 선택하는 경우의 수는 \(\binom{39}{30}\)입니다.
3. **확률 계산:**
- 확률은 \(\frac{\binom{39}{30}}{\binom{45}{30}}\)입니다.
계산
1. **총 경우의 수** \(\binom{45}{30}\) 계산:
\[
\binom{45}{30} = \frac{45!}{30! \times (45-30)!} = \frac{45!}{30! \times 15!}
\]
2. **바람직하지 않은 경우의 수** \(\binom{39}{30}\) 계산:
\[
\binom{39}{30} = \frac{39!}{30! \times (39-30)!} = \frac{39!}{30! \times 9!}
\]
3. **확률 계산**:
\[
P(\text{1등 번호 미포함}) = \frac{\binom{39}{30}}{\binom{45}{30}}
\]
수치 계산
- \(\binom{45}{30}\)의 값은 약 344,867,425,584 입니다.
- \(\binom{39}{30}\)의 값은 약 211,915,132 입니다.
따라서 확률은:
\[
P(\text{1등 번호 미포함}) = \frac{211,915,132}{344,867,425,584} \approx 0.00061448288901494
\]
이 확률은 약 0.061448288901494%입니다. 이는 30개의 숫자 중에 1등 번호가 하나도 포함되지 않을 확률이 매우 낮다는 것을 의미합니다.
통계적 검증
import random
import time
# Simulate lottery draws (number of simulations)
simulations = 1000000
progress_interval = simulations // 10 # Update progress every 1% of total simulations
favorable_cases = 0 # Initialize inside the loop
total_set = set(range(1, 46)) # 전체 집합
start_time = time.time()
for i in range(simulations):
# Winning numbers (replace with actual winning numbers if desired)
winning_numbers = set(random.sample(range(1, 46), 6))
# Choose 30 unique numbers from the total 45 numbers
chosen_30 = set(random.sample(sorted(total_set), 30))
# The remaining 15 numbers that are not chosen
remaining_numbers = total_set - chosen_30
# Check if the winning numbers are in the remaining 15 numbers
if set(winning_numbers).issubset(remaining_numbers):
favorable_cases += 1
# Print progress
if (i + 1) % progress_interval == 0:
elapsed_time = time.time() - start_time
percentage = (i + 1) / simulations * 100
estimated_total_time = (elapsed_time / (i + 1)) * simulations
remaining_time = estimated_total_time - elapsed_time
print(f"Progress: {percentage:.2f}% | Elapsed Time: {elapsed_time:.2f}s | Estimated Remaining Time: {remaining_time:.2f}s")
# Probability estimation
probability = favorable_cases / simulations
# Print final results
print(f"Estimated probability of NOT including all winning numbers in any of the 5 sets (without replacement, after {simulations} simulations): {probability:.10f}")
결과
Estimated probability of NOT including all winning numbers in any of the 5 sets (without replacement, after 1000000 simulations): 0.0006410000
39C9 / 45C15 로 계산할 수 있음.
1~45중에서 15개의 숫자를 선택하는 전체 경우 수 45C15
15개 숫자 중 6개의 당첨 번호를 미리 비워 두고, 나머지 39개의 숫자 중 나머지 15-6개의 자리를 채우는 경우의 수 39C9
2. 게임간 숫자 중복 선택을 허용할 때
문제 정의
- 전체 숫자: 1부터 45까지 (N = 45)
- 각 게임에서 선택하는 숫자: 6개 (k = 6)
- 게임 수: 5 (m = 5)
- 당첨 번호: 6개
우리는 5게임 중 어떤 게임에서도 6개의 당첨 번호가 포함되지 않을 확률을 구하려고 합니다.
1. 각 게임에서 당첨 번호가 포함되지 않을 확률
하나의 게임에서 특정 6개의 당첨 번호가 포함되지 않을 확률을 계산합니다.
- 전체 조합 수: \(\binom{45}{6}\)
- 특정 6개의 당첨 번호를 포함하지 않는 조합 수: \(\binom{39}{6}\) (총 45개 숫자에서 6개를 제외한 39개 숫자 중에서 6개를 선택하는 조합)
따라서, 하나의 게임에서 특정 6개의 당첨 번호가 포함되지 않을 확률은:
\[
P(\text{특정 번호 포함되지 않음}) = \frac{\binom{39}{6}}{\binom{45}{6}}
\]
2. 5게임 모두에서 당첨 번호가 포함되지 않을 확률
5게임 모두에서 특정 6개의 당첨 번호가 포함되지 않을 확률을 계산합니다. 각 게임이 독립적이라고 가정하면, 다음과 같이 계산할 수 있습니다:
\[
P(\text{5게임 모두에서 포함되지 않음}) = \left(\frac{\binom{39}{6}}{\binom{45}{6}}\right)^5
\]
3. 수식 계산
# 전체 조합 수 계산
- 전체 6개 숫자를 선택하는 조합의 수:
\[
\binom{45}{6} = \frac{45!}{6!(45-6)!} = 8{,}145{,}060
\]
# 특정 번호를 포함하지 않는 조합의 수
- 39개 숫자 중에서 6개를 선택하는 조합의 수:
\[
\binom{39}{6} = \frac{39!}{6!(39-6)!} = 3{,}262{,}623
\]
# 확률 계산
- 특정 번호가 포함되지 않을 확률:
\[
\frac{\binom{39}{6}}{\binom{45}{6}} = \frac{3{,}262{,}623}{8{,}145{,}060} \approx 0.4005
\]
- 5게임 모두에서 포함되지 않을 확률:
\[
\left(\frac{3{,}262{,}623}{8{,}145{,}060}\right)^5 \approx 0.010312477830338
\]
결론
따라서, 6개의 당첨 번호가 5게임 중 어디에도 포함되지 않을 확률은 약 0.01024 (즉, 약 1.024%)입니다.
통계적 검증
from scipy.special import comb
import random
import time
# Simulate lottery draws (number of simulations)
simulations = 1000000
progress_interval = simulations // 10 # Update progress every 1% of total simulations
favorable_cases = 0 # Initialize inside the loop
winning_numbers = set(random.sample(range(1, 46), 6))
# Initialize min and max length trackers
min_length = float('inf')
max_length = float('-inf')
start_time = time.time()
for i in range(simulations):
# Winning numbers (replace with actual winning numbers if desired)
# Generate 5 sets of 6 random numbers
chosen_numbers = [random.sample(range(1, 46), 6) for _ in range(5)]
# Flatten the list and remove duplicates
all_numbers = list(set([num for sublist in chosen_numbers for num in sublist]))
total_set = set(range(1, 46)) # 전체 집합
all_numbers_set = set(all_numbers) # all_numbers를 집합으로 변환
# 여집합 계산
all_other_numbers = total_set - all_numbers_set
# Update min and max length
current_length = len(all_numbers)
if current_length < min_length:
min_length = current_length
if current_length > max_length:
max_length = current_length
# Check if all winning numbers are included in the all_other_numbers
if set(winning_numbers).issubset(all_other_numbers):
favorable_cases += 1
# Print progress
if (i + 1) % progress_interval == 0:
elapsed_time = time.time() - start_time
percentage = (i + 1) / simulations * 100
estimated_total_time = (elapsed_time / (i + 1)) * simulations
remaining_time = estimated_total_time - elapsed_time
print(f"Progress: {percentage:.2f}% | Elapsed Time: {elapsed_time:.2f}s | Estimated Remaining Time: {remaining_time:.2f}s")
# Probability estimation
probability = favorable_cases / simulations
# Print final results
print(f"Minimum length of all_numbers across simulations: {min_length}")
print(f"Maximum length of all_numbers across simulations: {max_length}")
print(f"Estimated probability of NOT including all winning numbers in any of the 5 sets (after {simulations} simulations): {probability:.10f}")
Minimum length of all_numbers across simulations: 15
Maximum length of all_numbers across simulations: 30
Estimated probability of NOT including all winning numbers in any of the 5 sets (after 1000000 simulations): 0.0103890000
3. 반대의 경우 : 1등 번호를 모두 포함할 때
https://allcalc.org/45197
댓글1
-
세상의모든계산기
등위별 당첨 확률
등위 당첨방법 당첨확률 당첨금의 배분 비율 1등 6개 번호 일치 1 / 8,145,060
=0.00001228%
총 당첨금 중 4등, 5등 금액을 제외한 금액의 75% 2등 5개 번호 일치
+ 보너스 번호일치1 / 1,357,510
=0.00007366%총 당첨금 중 4등, 5등 금액을 제외한 금액의 12.5% 3등 5개 번호 일치 1 / 35,724
=0.00279924%
총 당첨금 중 4등, 5등 금액을 제외한 금액의 12.5% 4등 4개 번호 일치 1 / 733
=0.136425645%
50,000원 5등 3개 번호 일치 1 / 45
=2.222222222%
5,000원
세상의모든계산기 님의 최근 댓글
V2 갱신 (nonK / K-Type 통합형) 예전에는 직접 코드작성 + AI 보조 하여 프로그램 만들었었는데, 갈수록 복잡해져서 손 놓고 있었습니다. 이번에 antigravity 설치하고, 테스트 겸 새로 V2를 올렸습니다. 직접 코드작성하는 일은 전혀 없었고, 바이브 코딩으로 전체 작성했습니다. "잘 했다 / 틀렸다 / 계산기와 다르다." "어떤 방향에서 코드 수정해 봐라." AI가 실물 계산기 각정 버튼의 작동 방식에 대한 정확한 이해는 없는 상태라서, V1을 바탕으로 여러차례 수정해야 했습니다만, 예전과 비교하면 일취월장 했고, 훨씬 쉬워졌습니다. 2026 02.04 A) 1*3*5*7*9 = 계산 945 B) √ 12번 누름 ㄴ 12회 해도 되고, 14회 해도 되는데, 횟수 기억해야 함. ㄴ 횟수가 너무 적으면 오차가 커짐 ㄴ 결과가 1에 매우 가까운 숫자라면 된 겁니다. 1.0016740522338 C) - 1 ÷ 5 + 1 = 1.0003348104468 D) × = 을 (n세트) 반복해 입력 ㄴ 여기서 n세트는, B에서 '루트버튼 누른 횟수' 3.9398949655688 빨간 부분 숫자에 오차 있음. (소숫점 둘째 자리 정도까지만 반올림 해서 답안 작성) 참 값 = 3.9362834270354... 2026 02.04 1. 분모 먼저 계산 400 × 10000 = 100 × 6000 = GT 결과값 4,600,000 역수 처리 ÷÷== 결과값 0.00000021739 2. 분자 곱하기 ×3 00 00 00 ×4 00 ×1 00 00 최종 결과 = 2,608,695.65217 2026 02.04 해결 방법 1. t=-1 을 기준으로 그래프를 2개로 나누어 표현 ㄴ 근데 이것도 tstep을 맞추지 않으면 문제가 발생할 것기도 하고, 상관이 없을 것 같기도 하고... 모르겠네요. 2. t=-1 이 직접 계산되도록 tstep을 적절하게 조정 tstep=0.1 tstep=0.01 도 해 보고 싶지만, 구간 크기에 따라 최소 tstep 이 변하는지 여기서는 0.01로 설정해도 0.015로 바뀌어버립니다. 그래서 tstep=0.02 로 하는게 최대한 긴 그래프를 얻을 수 있습니다. 2026 02.02 불연속 그래프 ti-nspire는 수학자처럼 연속적인 선을 그리는 것이 아니라, 정해진 `tstep` 간격으로 점을 찍고 그 점들을 직선으로 연결하는 'connect-the-dots' 방식으로 그래프를 그립니다. 여기에 tstep 간격에 따라 특이점(분모=0)이 제외되어 문제가 나타난 것입니다. seq(−2+0.13*t,t,0,23) {−2.,−1.87,−1.74,−1.61,−1.48,−1.35,−1.22,−1.09,−0.96,−0.83,−0.7,−0.57,−0.44,−0.31,−0.18,−0.05,0.08,0.21,0.34,0.47,0.6,0.73,0.86,0.99} t=-1 에서 그래프를 찾지 않습니다. 그 좌우 값인 −1.09, −0.96 두 값의 그래프값을 찾고, Window 범위를 보고 적당히 (연속되도록) 이어서 그래프를 완성하는 방식입니다. 그래서 t=-1에서도 그래프 값이 존재하는 것입니다. 2026 02.02