- 다양한 주제에 대해 자유롭게 글을 작성하는 게시판입니다.
Date 17/02/08 10:35:42
Name   April_fool
Subject   로또 번호와 정규분포

어제의 일입니다. 부장님이 잡담하시는 것을 듣고 있는데, 문득 그 중에 “로또에서 각 번호들의 총합이 백 얼마인 것이 가장 당첨 확률이 높더라”는 내용이 있더군요. 당연한 게 아닌가? 싶기도 했지만, 그래도 왠지 확인을 해보고 싶더라고요.

그래서 다음과 같은 간단한 프로그램을 짜서 돌려 보았습니다.

  1. import random
  2.  
  3. def plusAll(a):
  4.     # 리스트 속에 있는 모든 숫자를 더해 반환한다.
  5.     result = 0
  6.     while len(a) != 0:
  7.         result += a.pop()
  8.     return result
  9.  
  10. def counter(a):
  11.     # 리스트 속의 원소의 개수를 세어 튜플로 반환한다.
  12.     result = {}
  13.     for i in a:
  14.         if i in result:
  15.             result[i] = result[i] + 1
  16.         else:
  17.             result[i] = 1
  18.     return result
  19.  
  20. = []
  21. for i in range(1000000+1):
  22.     b = random.sample(range(1, 45+1), 6)
  23.     a.append(plusAll(b))
  24. = counter(a)
  25. = sorted(b.items())
  26.  
  27. file1 = open("a.tsv", "w")
  28. for (k, v) in c:
  29.     line = str(k) + "\t" + str(v) + "\n"
  30.     file1.write(line)
  31. file1.close()

이 파이썬 프로그램은 랜덤으로 로또 번호를 백만 개 생성하여, 그 숫자들의 합이 몇 개나 나오는지 세어서 특정 파일에다가 그 결과를 기록합니다. 이 결과물은 Microsoft Excel에서 열어볼 수가 있지요. 그리고, 그 결과물을 엑셀에서 분산형 차트로 그려보면 다음과 같습니다.

 …어디서 많이 본 듯한 모양의 그래프가 나왔습니다. 제가 듣기로, 이런 모양을 가리켜 [정규분포]라고 한다고 하더군요.

그러면, 저 그래프에서 가장 높은 값(=가장 많이 나온 값)은 어디일까요? 생각해보면, 로또의 각 숫자를 더한 값 중 가장 작은 수는 1+2+3+4+5+6=21이고, 가장 큰 수는 45+44+43+42+41+40=255입니다. (21+255)÷2=138이지요. 실제로 생성된 파일의 데이터를 살펴보아도, 138 부근의 값이 가장 많이 나온 것을 알 수 있습니다. 다시 말해서, 이론적으로 로또의 각 숫자의 합이 138과 유사한 경우가 상대적으로 당첨 확률이 높다는 결론이 나옵니다. 이걸 응용하면 옛날에 타임라인에 올렸던 로또번호 생성 프로그램을 개량할 수 있을 것 같아요.

이상, 오늘의 월도짓이었습니다.




3


    목록
    번호 제목 이름 날짜 조회 추천
    4133 문화/예술레너드 코헨 - NPR 방송 3 까페레인 16/11/11 3963 0
    8459 게임레드 데드 리뎀션 2 리뷰 3 저퀴 18/11/04 3875 7
    6646 음악레드벨벳 앨범 수록곡 추천 6 은우 17/11/24 6046 0
    4578 게임레드티에서도 보드게임모임있나요? + 어썌신크리드4:블랙프래그리뷰 8 mathematicgirl 17/01/09 3805 0
    12064 게임레딧에서 뽑은 롤드컵 TOP 20 플레이어 4 Leeka 21/09/10 3284 0
    6350 도서/문학레미제라블 앙졸라스 이름 논쟁 13 코리몬테아스 17/09/27 9856 8
    2150 영화레버넌트와 서바이벌 17 Moira 16/01/31 4516 3
    1053 생활체육레버쿠젠과 손흥민 이야기 26 Raute 15/09/21 10316 4
    14307 스포츠레슬링계의 금쪽이 CM PUNK를 놓지 못하는 이유 4 danielbard 23/12/03 1742 6
    8240 일상/생각레쓰비 한 캔 5 nickyo 18/09/17 4994 31
    952 음악레인보우 A 3 표절작곡가 15/09/08 3662 0
    12995 정치레임덕입니다 58 매뉴물있뉴 22/07/13 4043 1
    10369 게임레전드 오브 룬테라 스마트폰 버전이 공개? 유출? 되었습니다. Leeka 20/03/11 4363 1
    3591 기타레전드 히어로 삼국전 공식 액션 영상모음 5 자동더빙 16/08/27 4347 0
    7970 방송/연예레전드가 되는 길: 이경규 vs 최양락 12 OSDRYD 18/07/30 6382 5
    3150 도서/문학레진코믹스 이용 한 달 후기 11 Raute 16/06/28 7460 2
    313 문화/예술레코딩의 이면 그리고 나만의 레퍼런스 만들기 30 뤼야 15/06/12 9561 0
    4156 일상/생각레퍼런스 하나 없는 나의 개똥철학들 16 Ben사랑 16/11/15 4490 0
    8367 일상/생각레포트용지 소동 9 OshiN 18/10/14 4659 10
    8859 스포츠로드 FC. 그 애잔한 '100만불 토너먼트'. 6 The xian 19/02/13 3570 0
    4831 IT/컴퓨터로또 번호 생성 프로그램과 정지 문제 11 April_fool 17/02/10 5696 1
    4805 기타로또 번호와 정규분포 33 April_fool 17/02/08 13428 3
    8772 음악로또의 꿈 2 바나나코우 19/01/18 3362 4
    1674 기타로마의 몰락, 파스타의 쇠퇴. 6 마르코폴로 15/12/01 6405 4
    11067 스포츠로마첸코-로페즈 : 초속과 변칙 3 Fate(Profit) 20/10/18 5235 6
    목록

    + : 최근 2시간내에 달린 댓글
    + : 최근 4시간내에 달린 댓글

    댓글