송민준의 개발노트

프로그래머스-level1-하샤드 수 본문

알고리즘/프로그래머스

프로그래머스-level1-하샤드 수

송민준 2019. 11. 20. 22:26

https://programmers.co.kr/learn/courses/30/lessons/12947

 

코딩테스트 연습 - 하샤드 수 | 프로그래머스

양의 정수 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

programmers.co.kr

처음에 문제를 보고 10으로 나눠서 배열에 하나씩 넣어야 하나? 라고 생각했지만 각 자릿수의 합을 구하는 문제는 굳이 그럴 필요가 없어서 바로 합계를 구했다.

쉬운 문제인듯...

 

class Solution {
  public boolean solution(int x) {
        int sum = 0; int a = x;
		 while(true) {
			 sum += x%10;
			 x = x/10;
			 if (x < 1) {break;}
		 }
	     return (a%sum==0);
  }
}

참고할 코드

람다식 풀이법이다. 항상 숫자가 들어있는 String을 chars로 쪼개서 활용하면 ASCII 코드의 값이 나와서 계산하는게 힘들었는데 이 사람은 0을 빼줬다.... 한 수 배웠음! 다만 내가 푼 방식보단 속도가 느릴듯