728x90
반응형

주사위 세개 성공

문제

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
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
#include <stdio.h>
 
 
int main()
{
    int A,B,C;
    scanf("%d %d %d",&A,&B,&C);
    
    if(A==B&&B==C){
        printf("%d",10000+A*1000);
    }else if(A!=B&&A!=C&&B!=C){
        int max;
        if(A>B&&A>C){
            max = A;
        }else if(B>A&&B>C){
            max = B;
        }else{
            max = C;
        }
        printf("%d",100*max);
    }else{
        
        int same;
        if(A==B){
            same = A;
        }else if(B==C){
            same = B;
        }else{
            same = C;
        }
        printf("%d",1000+same*100);
    }
 
}
cs

2번 조건을 구현하는게 가장 까다로워 보여 1, 3번 조건만 if문에 넣었다.

 

최대/최소 구현하는 방식을 사용해도 좋았겠다만 입력이 3개 밖에 없어서ㅎ

반응형

'백준 단계별로 풀어보기 > 조건문' 카테고리의 다른 글

백준 2525 오븐 시계  (0) 2022.09.19
백준 9498 시험 성적  (0) 2022.09.19
728x90
반응형

오븐 시계 성공

 
문제

KOI 전자에서는 건강에 좋고 맛있는 훈제오리구이 요리를 간편하게 만드는 인공지능 오븐을 개발하려고 한다. 인공지능 오븐을 사용하는 방법은 적당한 양의 오리 훈제 재료를 인공지능 오븐에 넣으면 된다. 그러면 인공지능 오븐은 오븐구이가 끝나는 시간을 분 단위로 자동적으로 계산한다. 

또한, KOI 전자의 인공지능 오븐 앞면에는 사용자에게 훈제오리구이 요리가 끝나는 시각을 알려 주는 디지털 시계가 있다. 

훈제오리구이를 시작하는 시각과 오븐구이를 하는 데 필요한 시간이 분단위로 주어졌을 때, 오븐구이가 끝나는 시각을 계산하는 프로그램을 작성하시오.

입력

첫째 줄에는 현재 시각이 나온다. 현재 시각은 시 A (0 ≤ A ≤ 23) 와 분 B (0 ≤ B ≤ 59)가 정수로 빈칸을 사이에 두고 순서대로 주어진다. 두 번째 줄에는 요리하는 데 필요한 시간 C (0 ≤ C ≤ 1,000)가 분 단위로 주어진다. 

출력

첫째 줄에 종료되는 시각의 시와 분을 공백을 사이에 두고 출력한다. (단, 시는 0부터 23까지의 정수, 분은 0부터 59까지의 정수이다. 디지털 시계는 23시 59분에서 1분이 지나면 0시 0분이 된다.)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <stdio.h>
 
int main(){
    int hour, min;
    int cook;
    
    scanf("%d %d",&hour,&min);
    scanf("%d",&cook);
    
    min+=cook;
  
        int newhour;
        newhour=min/60;
        min = min-60*newhour;
        hour += newhour;
        if(hour>=24) hour=0;
        printf("%d %d",hour, min);
    
    
    
}
cs

약간 야매로 구현했다.

현재 시간 hour 와 min 을 입력받는다.

min에 cook 을 더한다.

newhour 는 min을 60으로 나눈 결과로서, 60분이 넘었을 때 시간 단위를 의미한다.

min-60*newhour 은 min이 60 이하의 값을 가질 수 있도록 한다.

 

hour에 newhour을 더해준다.

디지털 시계이므로 23 59에 1분을 추가했을 경우 24 00이 아니라 0 0을 나타내야 한다.

따라서 hour이 24이상일 경우, hour에서 24를 제거함으로서 디지털 시계로 나타낼 수 있도록 한다.

 

요리하는데 필요한 시간이 1000분 이하였기 때문에 24만 제거해도 괜찮았다.

 

 

반응형

'백준 단계별로 풀어보기 > 조건문' 카테고리의 다른 글

백준 2480 주사위 세개  (1) 2022.09.20
백준 9498 시험 성적  (0) 2022.09.19
728x90
반응형

시험 성적 성공

문제

시험 점수를 입력받아 90 ~ 100점은 A, 80 ~ 89점은 B, 70 ~ 79점은 C, 60 ~ 69점은 D, 나머지 점수는 F를 출력하는 프로그램을 작성하시오.

 

입력

첫째 줄에 시험 점수가 주어진다. 시험 점수는 0보다 크거나 같고, 100보다 작거나 같은 정수이다.

출력

시험 성적을 출력한다.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <stdio.h>
 
int main(void){
    int score;
    scanf("%d"&score);
 
    if(score>=90)
        printf("A");
    else if(score>=80)
        printf("B");
    else if(score>=70)
        printf("C");
    else if(score>=60)
        printf("D");
    else
        printf("F");
}
 
cs

 

반응형

'백준 단계별로 풀어보기 > 조건문' 카테고리의 다른 글

백준 2480 주사위 세개  (1) 2022.09.20
백준 2525 오븐 시계  (0) 2022.09.19

+ Recent posts