일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
- java 백준 1차원 배열
- 리눅스마스터 3과목
- map
- 반복문
- Memoir
- 리눅스마스터 1급 정리
- 백준 javascript
- 리눅스마스터1급
- 연습문제
- 고잉버스
- Linux
- 코딩테스트
- 문자열
- 자바스크립트 코딩의 기술
- toCharArray
- 리눅스
- 코테
- 스프링 컨테이너
- Java
- 명령어
- 개발자 회고록
- 스프링 빈
- JavaScript
- 백준 java
- 프로그래머스
- GoingBus
- 월간코드챌린지
- Kotlin
- 카카오
- 자바
- Today
- Total
hoon's bLog
Java 프로그래머스 하샤드 수 자바 본문
문제 출처 : https://school.programmers.co.kr/learn/courses/30/lessons/12947
[문제 설명]
양의 정수 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) {
boolean answer = true;
char[] ch = String.valueOf(x).toCharArray();
int sum = 0;
for (int i = 0; i < ch.length; i++) {
sum += Integer.parseInt(String.valueOf(ch[i]));
}
if (x%sum == 0)
return answer;
else
answer = false;
return answer;
}
}
초기값 x를 문자열로 바꾼 후 문자 배열에 넣는다!
이후 for문을 통해 각 자릿수를 Integer.parsInt로 parsing 후 더하여 sum에 저장 후,
sum 값으로 x를 나눈 나머지가 0이면 true, 아니면 false!
[다른 사람들의 풀이-1]
public class HarshadNumber{
public boolean isHarshad(int num){
String[] temp = String.valueOf(num).split("");
int sum = 0;
for (String s : temp) {
sum += Integer.parseInt(s);
}
if (num % sum == 0) {
return true;
} else {
return false;
}
}
// 아래는 테스트로 출력해 보기 위한 코드입니다.
public static void main(String[] args){
HarshadNumber sn = new HarshadNumber();
System.out.println(sn.isHarshad(18));
}
}
나머지 로직은 비슷하지만,
첫 줄에 split 함수를 이용해, 2자리 숫자를 잘라, 문자 -> 문자열 변환 없이
문자열 배열에 바로 저장...
[다른 사람들의 풀이-2]
class Solution {
public boolean solution(int x) {
int sum = String.valueOf(x).chars().map(ch -> ch - '0').sum();
return x % sum == 0;
}
}
단 2줄??!?!?
String.chars()로 String 문자들을 stream을 만들어 줌.
Stream은 Java8에서 추가된 기능으로 함수형 인터페이스인 람다(lambda)를 활용할 수 있는 기술로,
코드의 양을 대폭 줄이고 조금 더 간결하게 코드를 작성할 수 있다!!
(자꾸 미뤄지는데 조만간 Stream 정리 예정!!!ㅠㅠ)
이후, 만들어진 Stream을 map을 통해 ch 요소들을 '0'을 빼서 문자로 만든 후 sum을 통해 더한다....캬아
[정리]
개인 피셜 난이도 : ★☆☆☆☆
쉬운 문제이나 역시 오늘도 배우는 데이터 처리 과정의 센스...
해당 문제를 올릴까 말까 고민했지만, 역시 Stream 공부차원에서 한번 올려봤다 ㅎㅎㅎ
빨리 나도 Stream 정리하고 내 것으로 만들어서,
짧은 문제풀이 해보고 싶다!
추가로, 난이도 한 개도 아까울 만큼 쉬워서 포스팅 건너뛴 문제들도 있다.
그런 문제들은 아래 내 github에서 검색하여 소스 참고하면 되겠다!
https://github.com/chrishoonS/codeTest
언제나 새로운 정보 공유와 잘못된 정보
비판/지적/태클은 환영입니다!
끝.
'코딩테스트 > 프로그래머스' 카테고리의 다른 글
Java 프로그래머스 K번째 수 자바 (3) | 2023.03.14 |
---|---|
Java 프로그래머스 완주하지 못한 선수 자바 (2) | 2023.02.23 |
Java 프로그래머스 제일 작은 수 제거하기 자바 (0) | 2023.02.09 |
[Java] 프로그래머스 정수 제곱근 판별 자바 (6) | 2023.02.08 |
Java 프로그래머스 정수 내림차순으로 배치하기 자바 (4) | 2023.02.07 |