Dorothy_YANG
With Dorothy
Dorothy_YANG
전체 방문자
오늘
어제
  • 분류 전체보기 (279)
    • Hi, I'm Dorothy 🕵️‍♂️ (21)
      • Slowly but Surely (18)
      • IT certifications (3)
    • 🤯TIL (80)
      • HTML & CSS (2)
      • Javascript & jQuery (13)
      • React (13)
      • C언어 (1)
      • JAVA (22)
      • Python (2)
      • Oracle SQL (10)
      • My SQL (5)
      • Spring (12)
    • 💻Programmers (17)
    • 🏫 Open API_JAVA (101)
    • 🌎 Project (10)
      • Shopping (10)
    • 💥 Error (24)
    • ⚙ Setting (23)

블로그 메뉴

  • 홈
  • 방명록

공지사항

인기 글

태그

  • 콜라보레이토리
  • 코딩앙마
  • 창초기화
  • HTML
  • SQLD합격후기
  • SQL
  • 기간쿼리
  • sql기간
  • Database
  • 이것이자바다
  • CSS
  • 노마드코더
  • AllArgsConstructor
  • 파이썬온라인
  • SQLD합격
  • googlecolaboratory
  • 백준
  • spring
  • 독학후기
  • 시작일종료일
  • 기간설정
  • 서버등록
  • oracle
  • Javascript
  • 오류해결
  • colaboratory
  • Eclipse
  • 연습문제
  • 비쥬얼스튜디오코드
  • java

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
Dorothy_YANG

With Dorothy

💻Programmers

[프로그래머스 / LV1] 하샤드 수(JAVA)

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

  • 제한 조건
    x는 1 이상, 10000 이하인 정수입니다.
  • 입출력 예
    x         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) {
        int num = x;
        int sum = 0;
        
        while(x > 0) {
            sum += x % 10;
            x /= 10;
        }
        return num % sum == 0 ? true : false;
    }
}
  • 문제풀이
    1) x를 10으로 나눈 몫들을 더해서 각 자릿수의 합을 구한다.
       > 그 후 x 값을 10으로 나눠서 자릿수를 하나씩 내려간다.
    2) 그렇게 구해진 각 자릿수의 합 sum를 기존의 x와 나눈다.
    3) 나머지가 0일 경우 true, 아닐 경우 false로 return하도록 했다.

    **int num = x; 를 따로 두지 않고 return 문에 x % sum 으로 시도하니 계속 오류가 났음.
    > 당연함. x는 이미 위에서 난도질 당한 x가 내려오기 때문에 초기값을 가져오려면 변수에 담아줘야 함

 

 

#다른 사람 풀이

public class HarshadNumber{
    public boolean isHarshad(int num){
    String [] tmp = String.valueOf(num).split("");
    int sum=0;
        for(String s:tmp) {
            sum+=Integer.parseInt(s);
        }
        if(num%sum==0) {
            return true;
        } else {
            return false;
        }
    }
}

- 임시저장 배열 tmp를 생성해서 String.valueOf(num).split("")을 사용해서 숫자를 하나씩 끊어서 담는다.
- 향상된 for문을 사용
   tmp 배열의 요소를 순회하며 sum에 하나씩 더한다.

 

향상된 for문 사용에 익숙해지자!

728x90
저작자표시 비영리 변경금지 (새창열림)

'💻Programmers' 카테고리의 다른 글

[프로그래머스 / LV1] 핸드폰 번호 가리기(JAVA)  (0) 2023.10.04
[프로그래머스 / LV1] 부족한 금액 계산하기(JAVA)  (1) 2023.10.03
[프로그래머스 / LV1] 나머지가 1이 되는 수 찾기(JAVA)  (0) 2023.10.03
[프로그래머스 / LV1] 콜라츠 추측(JAVA)  (0) 2023.10.01
[프로그래머스 / LV1] 자릿수 더하기(JAVA)  (0) 2023.10.01
    '💻Programmers' 카테고리의 다른 글
    • [프로그래머스 / LV1] 핸드폰 번호 가리기(JAVA)
    • [프로그래머스 / LV1] 부족한 금액 계산하기(JAVA)
    • [프로그래머스 / LV1] 나머지가 1이 되는 수 찾기(JAVA)
    • [프로그래머스 / LV1] 콜라츠 추측(JAVA)
    Dorothy_YANG
    Dorothy_YANG
    Slowly but Surely, 비전공 문과생의 개발공부

    티스토리툴바