주사위 세개

 
시간 제한메모리 제한제출정답맞힌 사람정답 비율
1 초 128 MB 50638 25380 22472 51.493%

문제

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

  1. 같은 눈이 3개가 나오면 10,000원+(같은 눈)×1,000원의 상금을 받게 된다. 
  2. 같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈)×100원의 상금을 받게 된다. 
  3. 모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)×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개 주사위의 나온 눈이 주어질 때, 상금을 계산하는 프로그램을 작성 하시오.

입력

첫째 줄에 3개의 눈이 빈칸을 사이에 두고 각각 주어진다. 

출력

첫째 줄에 게임의 상금을 출력 한다.

예제 입력 1 복사

3 3 6

예제 출력 1 복사

1300

예제 입력 2 복사

2 2 2

예제 출력 2 복사

12000

예제 입력 3 복사

6 2 5

예제 출력 3 복사

600

 

import java.util.Arrays;
import java.util.Scanner;

public class Question_2480 {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int[] numbers = new int[3];

        for (int i = 0; i < 3; i++) {
            numbers[i] = scanner.nextInt();
        }
        Arrays.sort(numbers);

        if (numbers[0] == numbers[2]) {
            System.out.println(10000 + numbers[0] * 1000);
        } else if (numbers[0] == numbers[1] || numbers[1] == numbers[2]) {
            System.out.println(1000 + numbers[1] * 100);
        } else {
            System.out.println(100 * numbers[2]);
        }
    }
}

첨엔 세개의 경우의수만 했는데 numbers[1] == numbers[2]의 경우의 수를 생각치 못해서 세 번이나 틀림 ㅠ

'알고리즘 > 여러가지' 카테고리의 다른 글

unordered_map VS map c++  (1) 2021.05.08
버블정렬 (Bubble Sort)  (0) 2021.04.27
선택정렬 (Selection Sort)  (0) 2021.04.27

map은 이진트리(Red_blackTree) unordered_map은 hash 방식.

map은 저장시 키값 기준으로 정렬 unordered_map은 key의 hash값에 따라 저장.

 

리소스 소비로는 unordered_map이 더 좋기 때문에 코테시 유리할듯

 

'알고리즘 > 여러가지' 카테고리의 다른 글

[백준] 2480 주사위 세개  (0) 2022.05.13
버블정렬 (Bubble Sort)  (0) 2021.04.27
선택정렬 (Selection Sort)  (0) 2021.04.27

버블 정렬이란?
서로 이웃한 데이터를 비교해 큰 수를 뒤로 보내고 작은 수를 앞으로 보내는 정렬
ex) 15, 1 -> 1, 15

#include <stdio.h>

int main(void) {
	int i, j, temp;
	int arr[10] = {10, 9, 8, 7, 6, 5, 4, 3, 2, 1};
	
	for(i=0; i<10; i++){
		for(j=0; j < 9-i; j++){
			if(arr[j] > arr[j + 1]){
				temp = arr[j];
				arr[j] = arr[j + 1];
				arr[j + 1] = temp;
			}
		}
	}
	
	for(i=0; i<10; i++){
		printf("%d ", arr[i]);
	}
	
    return 0;
}

시간복잡도 또한 O(N^2)

 

자바

public class BubbleSort {
    public static void main(String[] args) {
        int[] array = {10, 9, 8, 7, 6, 5, 4, 3, 2, 1};
        int temp;

        for(int i=1; i<= array.length; i++){
            for(int j=0; j< array.length-i; j++){
                if(array[j] > array[j+1]){
                    temp = array[j];
                    array[j] = array[j + 1];
                    array[j + 1] = temp;
                }
            }
        }

        for(int i=0; i<array.length; i++){
            System.out.printf("%d ", array[i]);
        }

    }
}

'알고리즘 > 여러가지' 카테고리의 다른 글

[백준] 2480 주사위 세개  (0) 2022.05.13
unordered_map VS map c++  (1) 2021.05.08
선택정렬 (Selection Sort)  (0) 2021.04.27

선택정렬이란 배열에서 가장 작은 숫자를 맨 앞으로 보내는것이다.

#include <stdio.h>

int main(void) {
	int arr[10] = {10, 9, 8, 7, 6, 5, 4, 3, 2, 1};
    int i, j, temp, min, index;
    
    for(i=0; i<10; i++){
    	min = 100;	// 배열에 있는 가장 큰 수보다 더 크게만 하면 됨
        for(j=i; j<10; j++){
        	if(min > arr[j]){
            	min = arr[j];
                index = j;
            }
        }
        temp = arr[i];			// 스와핑
        arr[i] = arr[index];
        arr[index] = temp;
    }
    
    for(i=0; i<10; i++){
    	printf("%d ", arr[i]);
    }
    return 0;
}

가장 직관적이고 이해하기 쉽지만 시간복잡도는 N * (N + 1)/2 이며 O(N^2)라고 한다.

 

자바

public class SelectionSort {
    public static void main(String[] args) {
        int[] array = {10, 9, 8, 7, 6, 5, 4, 3, 2, 1};
        int temp, i, j;
        int index=0;

        for(i=0; i<array.length; i++){
            int min=100;
            for(j=i; j<array.length; j++){
                if(min > array[j]){
                    min = array[j];
                    index = j;
                }
            }
            temp = array[i];
            array[i] = array[index];
            array[index] = temp;
        }
        for(i=0; i<array.length; i++){
            System.out.println(array[i]);
        }

    }
}

 

 

'알고리즘 > 여러가지' 카테고리의 다른 글

[백준] 2480 주사위 세개  (0) 2022.05.13
unordered_map VS map c++  (1) 2021.05.08
버블정렬 (Bubble Sort)  (0) 2021.04.27

+ Recent posts