반응형

# 1차원 배열

## 10818_최솟값과 최댓값을 찾는 문제

  • N개의 정수가 주어진다. 이때, 최솟값과 최댓값을 구하는 프로그램을 작성하시오.
  • 첫째 줄에 정수의 개수 N (1 ≤ N ≤ 1,000,000)이 주어진다. 둘째 줄에는 N개의 정수를 공백으로 구분해서 주어진다. 모든 정수는 -1,000,000보다 크거나 같고, 1,000,000보다 작거나 같은 정수이다.
  • 첫째 줄에 주어진 정수 N개의 최솟값과 최댓값을 공백으로 구분해 출력한다.
시간초과나옴.

import java.io.*;
class Main {
  public static void main(String[] args) throws IOException {
    BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
    BufferedWriter bf = new BufferedWriter(new OutputStreamWriter(System.out));

    int cnt = Integer.parseInt(br.readLine());
    String str = br.readLine();
    int temp = 0;

    int[] arr = new int[cnt];
    
    for (int i = 0; i < cnt; i++) {
      arr[i] = Integer.parseInt(str.split(" ")[i]);
    }

    for (int i = 1; i < cnt; i++) {
      for (int k = 0; k < cnt-i; k++) {
        if (arr[k] > arr[k+1]) {
          temp = arr[k];
          arr[k] = arr[k+1];
          arr[k+1] = temp;
        }
      }
    }

    bf.write(arr[0] + " " + arr[cnt-1]);

    bf.flush();
    
  }
}
import java.util.*;
class Main {
  public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);

    int cnt = sc.nextInt();
    int[] arr = new int[cnt];

    for (int i = 0; i < cnt; i++) {
      arr[i] = sc.nextInt();
    }

    Arrays.sort(arr);

    System.out.println(arr[0] + " " + arr[cnt-1]);
    
  }
}

## 2562_최댓값이 어디에 있는지 찾는 문제

9개의 서로 다른 자연수가 주어질 때, 이들 중 최댓값을 찾고 그 최댓값이 몇 번째 수인지를 구하는 프로그램을 작성하시오.

예를 들어, 서로 다른 9개의 자연수

3, 29, 38, 12, 57, 74, 40, 85, 61

이 주어지면, 이들 중 최댓값은 85이고, 이 값은 8번째 수이다.
  • 첫째 줄부터 아홉 번째 줄까지 한 줄에 하나의 자연수가 주어진다. 주어지는 자연수는 100 보다 작다.
  • 첫째 줄에 최댓값을 출력하고, 둘째 줄에 최댓값이 몇 번째 수인지를 출력한다.
import java.util.*;
class Main {
  public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);

    int cnt = 9;
    int[] arr = new int[cnt];
    int[] arr2 = new int[cnt];

    for (int i = 0; i < cnt; i++) {
      arr[i] = sc.nextInt();
      arr2[i] = arr[i];
    }

    Arrays.sort(arr);

    for (int i = 0; i < cnt; i++) {
      if (arr[cnt-1] == arr2[i]) {
        System.out.println(arr[cnt-1]);
        System.out.print(i+1);
      }
    }
    
  }
}
반응형

'알고리즘 > 프로그래머스, 백준, 구름' 카테고리의 다른 글

백준_while  (0) 2022.03.11
백준_for문  (0) 2022.03.11
백준_if문  (0) 2022.03.10
백준_입출력과 사칙연산  (0) 2022.03.09
[구름] 클래스 맴버, 인스턴스 맴버, 클래스 변수  (0) 2020.11.13
반응형

# while

## 10952_0 0이 들어올 때까지 A+B를 출력하는 문제

  • 두 정수 A와 B를 입력받은 다음, A+B를 출력하는 프로그램을 작성하시오.
  • 입력은 여러 개의 테스트 케이스로 이루어져 있다.
  • 각 테스트 케이스는 한 줄로 이루어져 있으며, 각 줄에 A와 B가 주어진다. (0 < A, B < 10)
  • 입력의 마지막에는 0 두 개가 들어온다.
  • 각 테스트 케이스마다 A+B를 출력한다.
import java.io.*;
class Main {
  public static void main(String[] args) throws IOException {
    BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
    BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));

    while(true) {
      String s = br.readLine();
      int num1 = Integer.parseInt(s.split(" ")[0]);
      int num2 = Integer.parseInt(s.split(" ")[1]);
      int cal = 0;

      cal = num1 + num2;

      if (num1 == 0 && num2 == 0) {
        break;
      }

      bw.write(cal + "\n");
    }
    
    bw.flush();
    
  }
}

## 10951_입력이 끝날 때까지 A+B를 출력하는 문제. EOF에 대해 알아 보세요.

  • 두 정수 A와 B를 입력받은 다음, A+B를 출력하는 프로그램을 작성하시오.
  • 입력은 여러 개의 테스트 케이스로 이루어져 있다.
  • 각 테스트 케이스는 한 줄로 이루어져 있으며, 각 줄에 A와 B가 주어진다. (0 < A, B < 10)
  • 각 테스트 케이스마다 A+B를 출력한다.
import java.util.*;
import java.io.*;
class Main {
  public static void main(String[] args) throws IOException {

    BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
    StringBuilder sb = new StringBuilder();
    StringTokenizer st;
    String s;

    while((s = br.readLine()) != null) {
      st = new StringTokenizer(s, " ");
      int a = Integer.parseInt(st.nextToken());
      int b = Integer.parseInt(st.nextToken());
      sb.append(a+b).append("\n");
    }

    System.out.print(sb);
    
  }
}

## 1110_원래 수로 돌아올 때까지 연산을 반복하는 문제

0보다 크거나 같고, 99보다 작거나 같은 정수가 주어질 때 다음과 같은 연산을 할 수 있다. 먼저 주어진 수가 10보다 작다면 앞에 0을 붙여 두 자리 수로 만들고, 각 자리의 숫자를 더한다. 그 다음, 주어진 수의 가장 오른쪽 자리 수와 앞에서 구한 합의 가장 오른쪽 자리 수를 이어 붙이면 새로운 수를 만들 수 있다. 다음 예를 보자.

26부터 시작한다. 2+6 = 8이다. 새로운 수는 68이다. 6+8 = 14이다. 새로운 수는 84이다. 8+4 = 12이다. 새로운 수는 42이다. 4+2 = 6이다. 새로운 수는 26이다.

위의 예는 4번만에 원래 수로 돌아올 수 있다. 따라서 26의 사이클의 길이는 4이다.

N이 주어졌을 때, N의 사이클의 길이를 구하는 프로그램을 작성하시오.
  • 첫째 줄에 N이 주어진다. N은 0보다 크거나 같고, 99보다 작거나 같은 정수이다.
  • 첫째 줄에 N의 사이클 길이를 출력한다.
반응형

'알고리즘 > 프로그래머스, 백준, 구름' 카테고리의 다른 글

백준_1차원 배열  (0) 2022.03.12
백준_for문  (0) 2022.03.11
백준_if문  (0) 2022.03.10
백준_입출력과 사칙연산  (0) 2022.03.09
[구름] 클래스 맴버, 인스턴스 맴버, 클래스 변수  (0) 2020.11.13
반응형

# for문

## 2739_구구단을 출력하는 문제

  • N을 입력받은 뒤, 구구단 N단을 출력하는 프로그램을 작성하시오. 출력 형식에 맞춰서 출력하면 된다.
  • 첫째 줄에 N이 주어진다. N은 1보다 크거나 같고, 9보다 작거나 같다.
  • 출력형식과 같게 N*1부터 N*9까지 출력한다
import java.util.Scanner;
class Main {
  public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);

    int num = sc.nextInt();

    for(int i = 1; i < 10; i++) {
      System.out.println(num + " * " + i + " = " + (num * i));
    }
    
  }
}

## 10950_A+B를 여러 번 출력하는 문제

  • 두 정수 A와 B를 입력받은 다음, A+B를 출력하는 프로그램을 작성하시오.
  • 첫째 줄에 테스트 케이스의 개수 T가 주어진다.
  • 각 테스트 케이스는 한 줄로 이루어져 있으며, 각 줄에 A와 B가 주어진다. (0 < A, B < 10)
  • 각 테스트 케이스마다 A+B를 출력한다.
import java.util.Scanner;
class Main {
  public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);

    int cnt = sc.nextInt();

    for (int i = 0; i < cnt; i++) {
      int num1 = sc.nextInt();
      int num2 = sc.nextInt();

      System.out.println(num1 + num2);
    }
    
    
  }
}

## 8393_1부터 N까지의 합을 구하는 문제. 물론 반복문 없이 풀 수도 있습니다.

  • n이 주어졌을 때, 1부터 n까지 합을 구하는 프로그램을 작성하시오.
  • 첫째 줄에 n (1 ≤ n ≤ 10,000)이 주어진다.
  • 1부터 n까지 합을 출력한다.
import java.util.Scanner;
class Main {
  public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);

    int cnt = sc.nextInt();
    int sum = 0;
    
    for (int i = 1; i <= cnt; i++) {
      sum += i;
    }

    System.out.println(sum);    
    
  }
}

## 15552_빠르게 입력받고 출력하는 문제

본격적으로 for문 문제를 풀기 전에 주의해야 할 점이 있다. 
입출력 방식이 느리면 여러 줄을 입력받거나 출력할 때 시간초과가 날 수 있다는 점이다.

C++을 사용하고 있고 cin/cout을 사용하고자 한다면, 
cin.tie(NULL)과 sync_with_stdio(false)를 둘 다 적용해 주고, 
endl 대신 개행문자(\n)를 쓰자. 
단, 이렇게 하면 더 이상 scanf/printf/puts/getchar/putchar 등 C의 입출력 방식을 사용하면 안 된다.

Java를 사용하고 있다면, Scanner와 System.out.println 대신 BufferedReader와 BufferedWriter를 
사용할 수 있다. BufferedWriter.flush는 맨 마지막에 한 번만 하면 된다.

Python을 사용하고 있다면, input 대신 sys.stdin.readline을 사용할 수 있다. 
단, 이때는 맨 끝의 개행문자까지 같이 입력받기 때문에 문자열을 저장하고 싶을 경우 
.rstrip()을 추가로 해 주는 것이 좋다.

또한 입력과 출력 스트림은 별개이므로, 테스트케이스를 전부 입력받아서 저장한 뒤 
전부 출력할 필요는 없다. 테스트케이스를 하나 받은 뒤 하나 출력해도 된다.

자세한 설명 및 다른 언어의 경우는 이 글에 설명되어 있다.

이 블로그 글에서 BOJ의 기타 여러 가지 팁을 볼 수 있다.
  • 첫 줄에 테스트케이스의 개수 T가 주어진다. T는 최대 1,000,000이다. 다음 T줄에는 각각 두 정수 A와 B가 주어진다. A와 B는 1 이상, 1,000 이하이다.
  • 각 테스트케이스마다 A+B를 한 줄에 하나씩 순서대로 출력한다.
import java.io.*;
class Main {
  public static void main(String[] args) throws IOException {
    BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
    BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));

    int cnt = Integer.parseInt(br.readLine());

    for (int i = 0; i < cnt; i++) {
      String num = br.readLine();
      int num1 = Integer.parseInt(num.split(" ")[0]);
      int num2 = Integer.parseInt(num.split(" ")[1]);
      
      bw.write(num1 + num2 + "\n");
    }
    
    bw.flush();
    
  }
}

## 2741_1부터 N까지 출력하는 문제

  • 자연수 N이 주어졌을 때, 1부터 N까지 한 줄에 하나씩 출력하는 프로그램을 작성하시오.
  • 첫째 줄에 100,000보다 작거나 같은 자연수 N이 주어진다.
  • 첫째 줄부터 N번째 줄 까지 차례대로 출력한다.
import java.io.*;
class Main {
  public static void main(String[] args) throws IOException {
    BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
    BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));

    int cnt = Integer.parseInt(br.readLine());

    for (int i = 1; i <= cnt; i++) {
      bw.write(i + "\n");
    }
    
    bw.flush();
    
  }
}

## 2742_제문 는하력출 지까N 터부1

  • 자연수 N이 주어졌을 때, N부터 1까지 한 줄에 하나씩 출력하는 프로그램을 작성하시오.
  • 첫째 줄에 100,000보다 작거나 같은 자연수 N이 주어진다.
  • 첫째 줄부터 N번째 줄 까지 차례대로 출력한다.
import java.io.*;
class Main {
  public static void main(String[] args) throws IOException {
    BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
    BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));

    int cnt = Integer.parseInt(br.readLine());

    for (int i = cnt; i >= 1; i--) {
      bw.write(i + "\n");
    }
    
    bw.flush();
    
  }
}

## 11021_A+B를 조금 더 아름답게 출력하는 문제

  • 두 정수 A와 B를 입력받은 다음, A+B를 출력하는 프로그램을 작성하시오.
  • 첫째 줄에 테스트 케이스의 개수 T가 주어진다.
  • 각 테스트 케이스는 한 줄로 이루어져 있으며, 각 줄에 A와 B가 주어진다. (0 < A, B < 10)
  • 각 테스트 케이스마다 "Case #x: "를 출력한 다음, A+B를 출력한다. 테스트 케이스 번호는 1부터 시작한다.
import java.io.*;
class Main {
  public static void main(String[] args) throws IOException {
    BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
    BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));

    int cnt = Integer.parseInt(br.readLine());

    for (int i = 1; i <= cnt; i++) {
      String num = br.readLine();
      int num1 = Integer.parseInt(num.split(" ")[0]);
      int num2 = Integer.parseInt(num.split(" ")[1]);

      int cal = num1 + num2;
      
      bw.write("Case #" + i + ": " + cal + "\n");
    }
    
    bw.flush();
    
  }
}

## 11022_A+B를 바로 위 문제보다 아름답게 출력하는 문제

  • 두 정수 A와 B를 입력받은 다음, A+B를 출력하는 프로그램을 작성하시오.
  • 첫째 줄에 테스트 케이스의 개수 T가 주어진다.
  • 각 테스트 케이스는 한 줄로 이루어져 있으며, 각 줄에 A와 B가 주어진다. (0 < A, B < 10)
  • 각 테스트 케이스마다 "Case #x: A + B = C" 형식으로 출력한다. x는 테스트 케이스 번호이고 1부터 시작하며, C는 A+B이다.
import java.io.*;
class Main {
  public static void main(String[] args) throws IOException {
    BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
    BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));

    int cnt = Integer.parseInt(br.readLine());

    for (int i = 1; i <= cnt; i++) {
      String num = br.readLine();
      int num1 = Integer.parseInt(num.split(" ")[0]);
      int num2 = Integer.parseInt(num.split(" ")[1]);

      int cal = num1 + num2;
      
      bw.write("Case #" + i + ": " + num1 + " + " + num2 + " = " + cal + "\n");
    }
    
    bw.flush();
    
  }
}

## 2438_별을 찍는 문제 1

  • 첫째 줄에는 별 1개, 둘째 줄에는 별 2개, N번째 줄에는 별 N개를 찍는 문제
  • 첫째 줄에 N(1 ≤ N ≤ 100)이 주어진다.
  • 첫째 줄부터 N번째 줄까지 차례대로 별을 출력한다.
import java.io.*;
class Main {
  public static void main(String[] args) throws IOException {
    BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
    BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));

    int cnt = Integer.parseInt(br.readLine());

    for (int i = 1; i <= cnt; i++) {
      for (int k = 1; k <= i; k++) {
        bw.write("*");  
      }
      bw.write("\n");
    }
    
    bw.flush();
    
  }
}

## 2439_별을 찍는 문제 2

  • 첫째 줄에는 별 1개, 둘째 줄에는 별 2개, N번째 줄에는 별 N개를 찍는 문제
  • 하지만, 오른쪽을 기준으로 정렬한 별(예제 참고)을 출력하시오.
  • 첫째 줄에 N(1 ≤ N ≤ 100)이 주어진다.
  • 첫째 줄부터 N번째 줄까지 차례대로 별을 출력한다.
import java.io.*;
class Main {
  public static void main(String[] args) throws IOException {
    BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
    BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));

    int cnt = Integer.parseInt(br.readLine());

    for (int i = 1; i <= cnt; i++) {

      for (int k = 1; k <= cnt-i; k++) {
        bw.write(" ");  
      }
      for (int k = 1; k <= i; k++) {
        bw.write("*");  
      }
      bw.write("\n");
    }
    
    bw.flush();
    
  }
}

## 10871_for와 if를 같이 쓰는 문제

  • 정수 N개로 이루어진 수열 A와 정수 X가 주어진다. 이때, A에서 X보다 작은 수를 모두 출력하는 프로그램을 작성하시오.
  • 첫째 줄에 N과 X가 주어진다. (1 ≤ N, X ≤ 10,000)
  • 둘째 줄에 수열 A를 이루는 정수 N개가 주어진다. 주어지는 정수는 모두 1보다 크거나 같고, 10,000보다 작거나 같은 정수이다.
  • X보다 작은 수를 입력받은 순서대로 공백으로 구분해 출력한다. X보다 작은 수는 적어도 하나 존재한다.
import java.io.*;
class Main {
  public static void main(String[] args) throws IOException {
    BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
    BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));

    String s = br.readLine();
    int cnt = Integer.parseInt(s.split(" ")[0]);
    int num = Integer.parseInt(s.split(" ")[1]);

    String ss = br.readLine();
    
    for (int i = 0; i < cnt; i++) {
      int cal = Integer.parseInt(ss.split(" ")[i]);

      if (num > cal) {
        bw.write(cal + " "); 
      }
    }
    
    bw.flush();
    
  }
}
반응형

'알고리즘 > 프로그래머스, 백준, 구름' 카테고리의 다른 글

백준_1차원 배열  (0) 2022.03.12
백준_while  (0) 2022.03.11
백준_if문  (0) 2022.03.10
백준_입출력과 사칙연산  (0) 2022.03.09
[구름] 클래스 맴버, 인스턴스 맴버, 클래스 변수  (0) 2020.11.13
반응형

# if문

## 1330_두 수를 비교한 결과를 출력하는 문제

  • 첫째 줄에 A와 B가 주어진다. A와 B는 공백 한 칸으로 구분되어져 있다.
  • 첫째 줄에 다음 세 가지 중 하나를 출력한다.
  • A가 B보다 큰 경우에는 '>'를 출력한다.
  • A가 B보다 작은 경우에는 '<'를 출력한다.
  • A와 B가 같은 경우에는 '=='를 출력한다.
import java.util.Scanner;
class Main {
  public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);

    int num1 = sc.nextInt();
    int num2 = sc.nextInt();

    if (num1 > num2) {
      System.out.println(">");
    } else if (num1 < num2) {
      System.out.println("<");
    } else if (num1 == num2) {
      System.out.println("==");
    }
  }
}

## 9498_시험 점수를 성적으로 바꾸는 문제

  • 첫째 줄에 시험 점수가 주어진다. 시험 점수는 0보다 크거나 같고, 100보다 작거나 같은 정수이다.
  • 시험 성적을 출력한다.
import java.util.Scanner;
class Main {
  public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);

    int num = sc.nextInt();

    if (num >= 90 && num <= 100) {
      System.out.println("A");
    } else if (num >= 80 && num < 90) {
      System.out.println("B");
    } else if (num >= 70 && num < 80) {
      System.out.println("C");
    } else if (num >= 60 && num < 70) {
      System.out.println("D");
    } else {
      System.out.println("F");
    }
  }
}

## 2753_윤년을 판별하는 문제

연도가 주어졌을 때, 윤년이면 1, 아니면 0을 출력하는 프로그램을 작성하시오.

윤년은 연도가 4의 배수이면서, 100의 배수가 아닐 때 또는 400의 배수일 때이다.

예를 들어, 2012년은 4의 배수이면서 100의 배수가 아니라서 윤년이다. 
1900년은 100의 배수이고 400의 배수는 아니기 때문에 윤년이 아니다. 
하지만, 2000년은 400의 배수이기 때문에 윤년이다.
  • 첫째 줄에 연도가 주어진다. 연도는 1보다 크거나 같고, 4000보다 작거나 같은 자연수이다.
  • 첫째 줄에 윤년이면 1, 아니면 0을 출력한다.
import java.util.Scanner;
class Main {
  public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);

    int year = sc.nextInt();

    // 윤년 1, 아니면 0
    // 윤년은 연도가 4의 배수이면서, 100의 배수가 아닐 때 또는 400의 배수일 때
    // 조건1 : 4의 배수이면서, 100의 배수가 아닐때. 또는(||)
    // => 4으로 나눴을때 나머지가 0, 100으로 나눴을땐 나머지가 0이 아닌경우.
    // 조건2 : 400의 배수.
    // => 400으로 나눴을때 나머지가 0인 경우.

    if ((year % 4 == 0 && year % 100 != 0) || (year % 400 == 0)) {
      System.out.println("1");
    } else {
      System.out.println("0");
    }
  }
}

## 14681_점이 어느 사분면에 있는지 알아내는 문제

  • 흔한 수학 문제 중 하나는 주어진 점이 어느 사분면에 속하는지 알아내는 것이다. 사분면은 아래 그림처럼 1부터 4까지 번호를 갖는다. "Quadrant n"은 "제n사분면"이라는 뜻이다.

  • 예를 들어, 좌표가 (12, 5)인 점 A는 x좌표와 y좌표가 모두 양수이므로 제1사분면에 속한다. 점 B는 x좌표가 음수이고 y좌표가 양수이므로 제2사분면에 속한다.
  • 점의 좌표를 입력받아 그 점이 어느 사분면에 속하는지 알아내는 프로그램을 작성하시오. 단, x좌표와 y좌표는 모두 양수나 음수라고 가정한다.
  • 첫 줄에는 정수 x가 주어진다. (−1000 ≤ x ≤ 1000; x ≠ 0) 다음 줄에는 정수 y가 주어진다. (−1000 ≤ y ≤ 1000; y ≠ 0)
  • 점 (x, y)의 사분면 번호(1, 2, 3, 4 중 하나)를 출력한다.
import java.util.Scanner;
class Main {
  public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);

    int num1 = sc.nextInt();
    int num2 = sc.nextInt();

    // 조건 1 : 양수, 양수 = 1
    // 조건 2 : 음수, 양수 = 2
    // 조건 3 : 음수, 음수 = 3
    // 조건 4 : 양수, 음수 = 4

    if (num1 > 0 && num2 > 0) {
      System.out.println("1");
    } else if (num1 < 0 && num2 > 0) {
      System.out.println("2");
    } else if (num1 < 0 && num2 < 0) {
      System.out.println("3");
    } else if (num1 > 0 && num2 < 0) {
      System.out.println("4");
    }
    
  }
}

## 2884_시간 계산 문제

상근이는 매일 아침 알람을 듣고 일어난다. 
알람을 듣고 바로 일어나면 다행이겠지만, 항상 조금만 더 자려는 마음 때문에 매일 학교를 지각하고 있다.

상근이는 모든 방법을 동원해보았지만, 조금만 더 자려는 마음은 그 어떤 것도 없앨 수가 없었다.

이런 상근이를 불쌍하게 보던, 창영이는 자신이 사용하는 방법을 추천해 주었다.

바로 "45분 일찍 알람 설정하기"이다.

이 방법은 단순하다. 원래 설정되어 있는 알람을 45분 앞서는 시간으로 바꾸는 것이다. 
어차피 알람 소리를 들으면, 알람을 끄고 조금 더 잘 것이기 때문이다. 
이 방법을 사용하면, 매일 아침 더 잤다는 기분을 느낄 수 있고, 학교도 지각하지 않게 된다.

현재 상근이가 설정한 알람 시각이 주어졌을 때, 창영이의 방법을 사용한다면, 
이를 언제로 고쳐야 하는지 구하는 프로그램을 작성하시오.
  • 첫째 줄에 두 정수 H와 M이 주어진다. (0 ≤ H ≤ 23, 0 ≤ M ≤ 59) 그리고 이것은 현재 상근이가 설정한 놓은 알람 시간 H시 M분을 의미한다.
  • 입력 시간은 24시간 표현을 사용한다. 24시간 표현에서 하루의 시작은 0:0(자정)이고, 끝은 23:59(다음날 자정 1분 전)이다. 시간을 나타낼 때, 불필요한 0은 사용하지 않는다.
  • 첫째 줄에 상근이가 창영이의 방법을 사용할 때, 설정해야 하는 알람 시간을 출력한다. (입력과 같은 형태로 출력하면 된다.)
import java.util.Scanner;
class Main {
  public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);

    int hh = sc.nextInt();
    int mm = sc.nextInt();

    int hDiff = 0;
    int mDiff = mm - 45;    

    if (mDiff >= 0) {
      System.out.println(hh + " " + mDiff);
    } else if (mDiff < 0) {
      hDiff = hh - 1;      
      mDiff = mDiff + 60;

      if (hDiff < 0)  {
        hDiff = 23;
      }      
      System.out.println(hDiff + " " + mDiff);
    }
    
        
    
  }
}

## 2525_범위가 더 넓은 시간 계산 문제

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

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

훈제오리구이를 시작하는 시각과 오븐구이를 하는 데 필요한 시간이 분단위로 주어졌을 때, 
오븐구이가 끝나는 시각을 계산하는 프로그램을 작성하시오.
  • 첫째 줄에는 현재 시각이 나온다. 현재 시각은 시 A (0 ≤ A ≤ 23) 와 분 B (0 ≤ B ≤ 59)가 정수로 빈칸을 사이에 두고 순서대로 주어진다. 두 번째 줄에는 요리하는 데 필요한 시간 C (0 ≤ C ≤ 1,000)가 분 단위로 주어진다.
  • 첫째 줄에 종료되는 시각의 시와 분을 공백을 사이에 두고 출력한다. (단, 시는 0부터 23까지의 정수, 분은 0부터 59까지의 정수이다. 디지털 시계는 23시 59분에서 1분이 지나면 0시 0분이 된다.)
import java.util.Scanner;
class Main {
  public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);

    int hh = sc.nextInt();
    int mm = sc.nextInt();
    int time = sc.nextInt();

    int mDiff = mm + time;

    if (mDiff < 60) {
      System.out.println(hh + " " + mDiff);
    } else if (mDiff >= 60) {
      hh = (hh + (mDiff / 60)) % 24;
      mDiff = mDiff % 60;
      System.out.println(hh + " " + mDiff);
    }  
   
  }
}

## 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개 주사위의 나온 눈이 주어질 때, 상금을 계산하는 프로그램을 작성 하시오.
  • 첫째 줄에 3개의 눈이 빈칸을 사이에 두고 각각 주어진다. 
  • 첫째 줄에 게임의 상금을 출력 한다.
import java.util.Scanner;
class Main {
  public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);

    int num1 = sc.nextInt();
    int num2 = sc.nextInt();
    int num3 = sc.nextInt();

    int money = 0;
    
    if (num1 == num2 && num1 == num3) {
      money = 10000 + (num1 * 1000);
    } else if (num1 == num2 || num2 == num3 || num1 == num3) {
      if (num1 == num2) {
        money = 1000 + (num1 * 100);
      } else if (num2 == num3) {
        money = 1000 + (num2 * 100);
      } else if (num1 == num3) {
        money = 1000 + (num1 * 100);
      }
    } else if (num1 != num2 && num1 != num3) {
      if (num1 >= num2 && num1 >= num3 ) {
        money = num1 * 100;
      } else if (num2 >= num1 && num2 >= num3) {
        money = num2 * 100;
      } else if (num3 >= num1 && num3 >= num2) {
        money = num3 * 100;
      }
    }

    System.out.println(money);
    
  }
}
반응형

+ Recent posts