[프로그래머스]Level 1 : 하샤드 수(JAVA)

2021. 5. 23. 20:35·코딩 테스트/Java
반응형
하샤드 수

 

문제 설명

양의 정수 x가 하샤드 수이려면 x의 자릿수의 합으로 x가 나누어져야 합니다. 예를 들어 18의 자릿수 합은 1+8=9이고, 18은 9로 나누어 떨어지므로 18은 하샤드 수입니다. 자연수 x를 입력받아 x가 하샤드 수인지 아닌지 검사하는 함수, solution을 완성해주세요.

제한 조건
  • x는 1 이상, 10000 이하인 정수입니다.
입출력 예
arr return
10 true
12 true
11 false
13 false
입출력 예 설명

입출력 예 #1
10의 모든 자릿수의 합은 1입니다. 10은 1로 나누어 떨어지므로 10은 하샤드 수입니다.

입출력 예 #2
12의 모든 자릿수의 합은 3입니다. 12는 3으로 나누어 떨어지므로 12는 하샤드 수입니다.

입출력 예 #3
11의 모든 자릿수의 합은 2입니다. 11은 2로 나누어 떨어지지 않으므로 11는 하샤드 수가 아닙니다.

입출력 예 #4
13의 모든 자릿수의 합은 4입니다. 13은 4로 나누어 떨어지지 않으므로 13은 하샤드 수가 아닙니다.

코드
class Solution {
    public boolean solution(int x) {
        boolean answer = false;
        String str = x + "";
        int sum = 0;
        
        for(int i=0; i<str.length(); i++){
            char c = str.charAt(i);
            sum += (int)c - 48;
        }
        return x % sum == 0 ? true : false;
    }
}
해설

이 문제에서 중요한 부분은 int형을 한자리씩 쪼개서 덧셈을 구해야 하는 것이다.

int x에 ""; 공백을 더해서 String형으로 변환을 시켜준 후 

cahrAt(i) 메서드를 사용해서 한글자씩 뽑아낸후 char c를 int형으로 형변환후 하나씩 sum에 더해줬다.

여기서 주의할점은 char형을 int형으로 바꿔줄때 -48을 해줘야야한다. 48은 아스키코드값으로 0 이다.

 

출처 : 프로그래머스, https://programmers.co.kr/learn/courses/30/lessons/12947

반응형
저작자표시 (새창열림)

'코딩 테스트 > Java' 카테고리의 다른 글

[프로그래머스]Level 1 : 수박수박수박수박수박수?(JAVA)  (0) 2021.05.27
[프로그래머스]Level 1 : 평균 구하기(JAVA)  (0) 2021.05.23
[프로그래머스]Level 1 : 핸드폰 번호 가리기(JAVA)  (0) 2021.05.23
[프로그래머스]Level 1 : 문자열을 정수로 바꾸기(JAVA)  (0) 2021.05.18
[프로그래머스]Level 1 : 짝수와 홀(JAVA)  (0) 2021.05.17
'코딩 테스트/Java' 카테고리의 다른 글
  • [프로그래머스]Level 1 : 수박수박수박수박수박수?(JAVA)
  • [프로그래머스]Level 1 : 평균 구하기(JAVA)
  • [프로그래머스]Level 1 : 핸드폰 번호 가리기(JAVA)
  • [프로그래머스]Level 1 : 문자열을 정수로 바꾸기(JAVA)
:j
:j
ddongjunn@gmail.com
  • :j
    dev.j
    :j
  • 전체
    오늘
    어제
    • :j
      • 프로그래밍 언어
        • Java
        • html
        • JavaScript
        • XML
        • JSON
        • CSS
        • jQuery
        • Web
        • k8s
        • JPA
      • 프레임워크
        • Spring
      • 코딩 테스트
        • Java
      • 네트워크
        • CCNA
      • 데이터베이스
        • Mssql
        • Oracle
      • 회고
      • :j story
      • CS
  • 블로그 메뉴

    • 홈
    • 태그
    • github
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    HAVING
    항해솔직후기
    Queue
    항해백앤드
    항해플러스백엔드
    Name
    오버라이딩
    항해99
    MSSQL
    group by
    오버로딩
    id
    <br>
    항해플러스
    class
    appendChild
    지역변수
    항해플러스백앤드
    다형성
    멤버변수
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
:j
[프로그래머스]Level 1 : 하샤드 수(JAVA)
상단으로

티스토리툴바