[백준] 3052번: 나머지 (Python, Java)

째리·2025년 2월 1일

코테연습

목록 보기
2/11

*카운트 배열 이용

문제

두 자연수 A와 B가 있을 때, A%B는 A를 B로 나눈 나머지 이다. 예를 들어, 7, 14, 27, 38을 3으로 나눈 나머지는 1, 2, 0, 2이다.

수 10개를 입력받은 뒤, 이를 42로 나눈 나머지를 구한다. 그 다음 서로 다른 값이 몇 개 있는지 출력하는 프로그램을 작성하시오.

입력

첫째 줄부터 열번째 줄 까지 숫자가 한 줄에 하나씩 주어진다. 이 숫자는 1,000보다 작거나 같고, 음이 아닌 정수이다.

출력

첫째 줄에, 42로 나누었을 때, 서로 다른 나머지가 몇 개 있는지 출력한다.

내 코드

Python

check = [0] * 42

for i in range(10):
  n = int(input())
  check[n % 42] = 1

sum = 0
for i in range(42):
  sum += check[i]

print(sum)

Java

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {

        Scanner sc = new Scanner(System.in);
        int[] arr = new int[42];
        for (int i = 0; i < 10; i++) {
            arr[sc.nextInt() % 42] = 1;
        }

        int sum = 0;
        for (int a : arr) {
            sum += a;
        }
        System.out.println(sum);
    }
}

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

2개의 댓글

comment-user-thumbnail
2025년 2월 1일

문제 푸시느라 정말 고생 많으셨습니다. 포스팅도 잘 봤어요! 자바랑 파이썬 동시에 하시나봐요. 대단하십니당.
그 혹시 체계적으로 코딩 테스트를 준비하고 싶으시다면, 백준에서 푼 문제를 쉽게 복습하고 아카이빙할 수 있는 mycodingtest.com 서비스를 사용해보시면 어떠실까요? 태깅, 요소별 정렬 등 다양한 기능을 제공하니 한 번 이용해보시면 좋을 것 같아요! 제 개인 프로젝트인데, 백준을 이용하시는 분들께 틈틈이 소개해 드리고 있습니다. 😊

1개의 답글