반응형

** 배열 사용하여 로또번호 6개 뽑기 **

 


#include "stdafx.h"
#include <stdio.h>
#include <random>
using namespace std;

 

//로또번호 생성기


int main()
{
 random_device rn;
 mt19937_64 rnd(rn());
 uniform_int_distribution<int> range(1, 45);

// 랜덤수 출력 함수

 


 int a[45] = { 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45 };
 int tmp=0;
 
 int ran1 = 0;
 int ran2 = 0;

 

 for (int i = 0; i < 100000; i++) {
  
  ran1 = range(rnd);
  ran2 = range(rnd);
  
  tmp = a[ran1-1];
  a[ran1-1] = a[ran2-1];
  a[ran2-1] = tmp;
  
 } // 카드를 2장뽑아서 섞는다.
 
 for (int j = 0; j < 6; j++) {
  printf("%d ", a[j]);
 } // 배열의 1~6까지 출력

 

    return 0;
}

 

********************************************************************************************************************************************

 

** 로또 번호 출력하여 10장 뽑기 **


#include "stdafx.h"
#include <stdio.h>
#include <random>
using namespace std;

//로또번호 생성기
int main()
{
 random_device rn;
 mt19937_64 rnd(rn());
 uniform_int_distribution<int> range(1, 45);
 int a[45] = { 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45 };
 int tmp=0;
 
 int ran1 = 0;
 int ran2 = 0;
 for (int k = 0; k < 10; k++) {
  for (int i = 0; i < 100000; i++) {

   ran1 = range(rnd);
   ran2 = range(rnd);

   tmp = a[ran1 - 1];
   a[ran1 - 1] = a[ran2 - 1];
   a[ran2 - 1] = tmp;

  }

  for (int j = 0; j < 6; j++) {
   if (0 < a[j] && a[j] < 10) {
    printf("  %d", a[j]);
   }
   else
    printf(" %d", a[j]);
  }
  printf("\n");
 }
    return 0;
}

 

********************************************************************************************************************************************

 

 

**  로또번호 생성기 OMR 마킹 방식  **

 


#include "stdafx.h"
#include <stdio.h>
#include <random>
using namespace std;

//로또번호 생성기 OMR 마킹 방식
int main()
{
 random_device rn;
 mt19937_64 rnd(rn());
 uniform_int_distribution<int> range(1, 45);
 
 int a[45];

 


 int ran1 = 0;
 int cnt = 0;

 for (int i = 0; i < 11; i++) {
  for (int q = 0; q < 45; q++)
  {
   a[q] = q + 1;
  }
  while (cnt < 6) {

   ran1 = range(rnd);
   if (a[ran1 - 1] != 0) {
    printf("%3d ", a[ran1 - 1]);
    a[ran1 - 1] = 0;
    cnt++;
   }

  }
  printf("\n");
  cnt = 0;
 }
   
   
 
    return 0;
}

 

********************************************************************************************************************************************

 

 

반응형

'Study > C' 카테고리의 다른 글

C언어 - 배열 (빙고판 만들기)  (0) 2018.08.24
C언어 - 배열 (2차원배열)  (0) 2018.08.24
C언어 과제1  (0) 2018.08.21
C언어 과제2  (0) 2018.08.21
연산자의 활용  (0) 2016.02.26
반응형

 연산자

기능 

결합방향 

 =

 연산자 오른쪽에 있는 값을 연산자 왼쪽에 있는 변수에 대힙한다 

 <- 

 +

 두 피연산자의 값을 더한다 

 ->

 -

 왼쪽의 피연산자 값에서 오른쪽의 피연산자 값을 뺀다 

 -> 

 *

 두 피연산자의 값을 곱한다 

 -> 

 /

 왼쪽의 피연산자 값을 오른쪽의 피연산자 값으로 나눈다 

 -> 

 %

 왼쪾의 피연산자 값을 오른쪽의 피연산자 값으로 나눴을 때 얻게 되는 나머지를 반환한다. 

 ->

 ++num

 값을 1 증가후, 속한 문장의 나머지를 진행(선증가 후 연산) 

 <- 

 num++

 속한 문장을 먼저 진행한 후 값을 1증가(선연산 후 증가) 

 ->

 --num

 값을 1 감소후, 속한 문장의 나머지를 진행(선 감소후 연산) 

 <-

 num--

  속한 문장을 진행한 후 값을 1 감소(선 연산후 감소)

 ->

 <

 예  n1<n2

 n1이 n2보다 작은가? 

 -> 

 >

 예 n1>n2

 n1이 n2보다 큰가? 

 ->

 ==

 예 n1==n2

 n1과 n2가 같은가?

 ->

 !=

 예 n1 != n2

 n1과 n2가 다른가?

 ->

 <=

 예 n1<=n2

 n1이 n2보다 같거나 작은가?

 ->

 >=

 예 n1>=n2

 n1이 n2보다 같거나 큰가?

 ->

 &&

 예 A&&B

 A와 B모두 참이면 연산결과로 참을 반환(논리 AND 

 ->

 ||

 예 A||B

 A와 B 둘중 하나라도 참이면 연산결과로 참을 반환(논리 OR) 

 ->

 !

 예 A!

 A가 참이면 거짓, A가 거짓이면 참을 반환(논리 NOT) 

 <-

 

반응형

'Study > C' 카테고리의 다른 글

C언어 - 배열 (빙고판 만들기)  (0) 2018.08.24
C언어 - 배열 (2차원배열)  (0) 2018.08.24
C언어 - 배열 (로또번호 난수발생기)  (0) 2018.08.24
C언어 과제1  (0) 2018.08.21
C언어 과제2  (0) 2018.08.21

+ Recent posts