반응형
https://www.acmicpc.net/problem/2480
풀이
#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 |