반응형

1. 문제

- [백준 C#] 2480번 주사위 세개
// https://www.acmicpc.net/problem/2480

 

 

1에서부터 6까지의 눈을 가진 3개의 주사위를 던져서 다음과 같은 규칙에 따라 상금을 받는 게임이 있다. 

같은 눈이 3개가 나오면 10,000원+(같은 눈)×1,000원의 상금을 받게 된다. 
같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈)×100원의 상금을 받게 된다. 
모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)×100원의 상금을 받게 된다.  
예를 들어, 3개의 눈 3, 3, 6이 주어지면 상금은 1,000+3×100으로 계산되어 1,300원을 받게 된다. 또 3개의 눈이 2, 2, 2로 주어지면 10,000+2×1,000 으로 계산되어 12,000원을 받게 된다. 3개의 눈이 6, 2, 5로 주어지면 그중 가장 큰 값이 6이므로 6×100으로 계산되어 600원을 상금으로 받게 된다.

3개 주사위의 나온 눈이 주어질 때, 상금을 계산하는 프로그램을 작성 하시오.

 

 

2. 문제 포인트

  • 3개의 수를 입력 받는다
  • 3개의 수를 오름 차순 정렬한다
  • 1,2번째 수를 비교, 2,3번째 수를 비교해서 같은 숫자가 몇개 있는지 확인한다.

 

 

반응형

 

 

3. 전체 코드

using System;

namespace B4_02480번
{
    internal class Program
    {
        static void Main(string[] args)
        {
            int[] num = Array.ConvertAll(Console.ReadLine().Split(), int.Parse);

            // 입력받은 배열 num을 오름차순 정렬
            Array.Sort(num);

            if (num[0] == num[1] && num[1] == num[2])
            {
                Console.WriteLine(10000 + (num[0]*1000));
            }
            else if (num[0] == num[1] || num[1] == num[2])
            {
                // 꼭 가운데 값인 num[1]을 곱해야 한다.
                // ex. 1, 1, 2 / 1, 2, 2  두 경우 모두 가운데 수가 앞 또는 뒷 숫자와 일치
                // 1번째 3번째 숫자는 일치 할 수 없음
                //// 오름차순 정렬이기에 불가 (1. 3번만 같고 2번이 다를 수 있는 경우 없음)
                //// 세가지 숫자가 같아야 하는데 위의 if문에서 걸러지기에 무관
                Console.WriteLine(1000 + (num[1] * 100));
            }
            else
            {
                // 오름차순 정렬을 했기에 num[2]가 가장 큰 수
                Console.WriteLine(num[2] * 100);
            }
        }
    }
}

// 2480번 주사위 세개
// https://www.acmicpc.net/problem/2480
반응형

+ Recent posts