본문 바로가기

알고리즘/Map, Set

[백준] 3052 : 나머지(java)

728x90
반응형

[백준] 3052 : 나머지(java)

 


문제

- 두 자연수 A와 B가 있을 때, A%B는 A를 B로 나눈 나머지 이다. 예를 들어, 7, 14, 27, 38을 3으로 나눈 나머지는 1, 2, 0, 2이다. 수 10개를 입력받은 뒤, 이를 42로 나눈 나머지를 구한다. 그 다음 서로 다른 값이 몇 개 있는지 출력하는 프로그램을 작성하시오.

 

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

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

 

코드

해설

-> boolean 배열을 42 크기로 생성하여 나머지의 값에 해당하는 부분을 true로 변경하여 출력하였다.

-> 다른 사람들은 어떻게 풀었을지에 대해 궁금해서 찾아보게 되었고 적절한 자료형을 사용하면 훨씬 간단하고 편하게 풀 수 있는 문제였다.


< HashSet을 활용한 해결방법 >

HashSet 정의 및 특징

  • Java Collection 중 Set의 대표적인 구현 파생 클래스
  • 기본적으로 집합이며 중복된 원소를 허용하지 않는다.
  • 순서를 고려하지 않는다.
728x90
반응형