IT 프로그래밍/백준

[c++] 2480 주사위 세개

기술1 2024. 3. 14. 22:58
반응형

https://www.acmicpc.net/problem/2480

 

2480번: 주사위 세개

1에서부터 6까지의 눈을 가진 3개의 주사위를 던져서 다음과 같은 규칙에 따라 상금을 받는 게임이 있다. 같은 눈이 3개가 나오면 10,000원+(같은 눈)×1,000원의 상금을 받게 된다. 같은 눈이 2개만

www.acmicpc.net

풀이


#include <iostream>

using namespace std;

int main()
{
	int a, b, c;
	cin >> a >> b >> c;

	if (a == b && b == c)
		cout << 10000 + a * 1000;
	else if (a == b || a == c)
		cout << 1000 + a * 100;
	else if (b == c)
		cout << 1000 + b * 100;
	else if(a > b && a > c)
		cout << a * 100;
	else if (b > c && b > a)
		cout << b * 100;
	else if (c > a && c > b)
		cout << c * 100;

	return 0;
}

다소 무식하다면 무식한 방식으로 푼 것 같다.

계속해서 else if 를 사용해주었다. 

 

이것이 물론 정답은 나왔지만 뭔가 깔끔하지 못한 풀이 같기도 하고 나 또한 다른 풀이 방식이 있으면 알고 싶어서 구글링을 통해 한가지 더 풀이를 가져왔다.

 

바로 max() 함수를 사용한 방식이었다.

 

다른 경우를 모두 하려니깐 나 같은 경우 조건이 길어졌는데 max함수를 사용할 경우 a, b, c에서 max의 경우를 통해 * 를 할 수 있으므로 더 간단하게 식이 구현될 수 있었다.

 

#include <iostream>
using namespace std;

int main(){
    int a, b, c, reward=0;
    cin >> a >> b >> c;
    
    if (a==b && b==c){ //같은 눈이 3개일 때
        reward = 10000 + a*1000;
    }
    else if (a==b || a==c){ //같은 눈이 2개일 대
        reward = 1000 + a*100;
    }
    else if (b==c){ //같은 눈이 2개일 때
        reward = 1000 + b*100;
    }
    else { //모두 다른 눈일 때
        reward = max(max(a,b),c) * 100;
    }
    
    cout << reward;
    
    return 0;

같은 눈이 3개일 때 이런 식으로 하는 것은 나와 동일했다. 

 

하지만 나는 cout을 if문마다 해줬는데 reward라는 함수를 정의해준 다음 cout <<를 통해 마지막에 출력하니 더 깔끔하여서 이 방식이 더 마음에 드는 것 같다.

 

else if는 대개 비슷한데 다른 모두 다른 눈일 때 나는 각각을 다 해줬는데 여기서는 max(max(a,b,), c)를통해 한번의 코드로 진행이 될 수 있게 해주었다. max는 두개의 함수만 비교가 가능하므로 저렇게 max 안에 max를 집어넣어서 해준 것을 볼 수 있다. 

 

나아가야 할 점 

1. max() 문을 생각해냈다면 더 간단하게 풀 수 있는 문제였다.

2. cout을 매번 하지 말고 reward라는 변수를 정해준 다음 마지막에 cout << reward;만 해주면 더 깔끔해진다. 

반응형

'IT 프로그래밍 > 백준' 카테고리의 다른 글

[C++] 백준 10950번 A+B -3  (0) 2024.03.15
[C++] 백준 2739번 구구단  (0) 2024.03.15
[c++] 백준 2525번 오븐 시계  (0) 2024.03.14
[c++] 백준 2284번 알람시계  (0) 2024.03.14
[백준] 14681번 사분면 고르기 [C++]  (0) 2024.03.06