프로그래머스의 알고리즘 문제 및 풀이에 대해 차근차근 포스팅하려합니다.
저도 초보자이기도하고 알고리즘에 쉽게 다가갈 수 없는 부분들이 많기 때문에
최대한 알기 쉽게 정리해보려하고 알고리즘을 어려워하는 분들에게 도움이 되었으면 합니다.
많이 공유되고 토론이 될 수 있는 공간이 되었으면 좋겠습니다.
환경
언어 : 자바
단계 : 레벨 1단계 (입문자용)
정답률 : 84%
제목
핸드폰 번호 가리기
문제 설명 및 코드
프로그래머스 모바일은 개인정보 보호를 위해 고지서를 보낼 때 고객들의 전화번호의 일부를 가립니다.
전화번호가 문자열 phone_number로 주어졌을 때, 전화번호의 뒷 4자리를 제외한 나머지 숫자를 전부 *으로 가린 문자열을 리턴하는 함수, solution을 완성해주세요.
제한 조건
- phone_number는 길이 4 이상, 20이하인 문자열입니다.
1
2
3
4
5
6
7
|
class Solution {
public String solution(String phone_number) {
String answer = "";
return answer;
}
}
|
cs |
입출력 예
phone_number | return |
"01033334444" | "*******4444" |
"027778888" | "*****8888" |
문제 정답 코드
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
class Solution {
public String solution(String phone_number) {
StringBuilder strBld = new StringBuilder();
for(int a=0; a<phone_number.length(); a++){
if(phone_number.length()-4 <= a){
strBld.append(phone_number.charAt(a) - '0');
}else{
strBld.append("*");
}
}
return strBld.toString();
}
}
|
cs |
저는 폰 번호가 들어있는 phone_number 문자열 변수의 값을 반복하여
문자열 길이에서 4를 뺀 값들은 숫자를 넣고 아니면 *를 넣어줘서
StringBuilder를 이용하여 문자열을 붙여주었습니다.
그리고 마지막 return 값에 toString으로 문자열을 넣어주었습니다.
다른사람 풀이
1
2
3
4
5
6
7
8
9
|
class Solution {
public String solution(String phone_number) {
char[] ch = phone_number.toCharArray();
for(int i = 0; i < ch.length - 4; i ++){
ch[i] = '*';
}
return String.valueOf(ch);
}
}
|
cs |
toCharArray는 문자열을 한 글자씩 쪼개서 이를 char타입 배열에 넣어주는 메서드입니다.
배열값이 들어가고 배열길이에서 4를 뺀 숫자만큼 돌면서 * 를 넣어주고
마지막에 형변환하여 리턴해줍니다.
정말 간결한 소스코드네요~
1
2
3
4
5
|
class Solution {
public String solution(String phone_number) {
return phone_number.replaceAll(".(?=.{4})", "*");
}
}
|
cs |
이번 코드는 replaceAll, 즉 정규식을 이용한 풀이입니다.
해석해보자면
. : 임의의 문자 한 개
(?=.) : 뒷쪽에 임의의 문자 한 개를 제외하고 선택
{4} : 숫자 만큼의 자릿수
.(?=.{4}) : 뒤쪽에서 임의의 문자 4개를 제외한 임의의 문자 한 개 선택
즉, 뒤쪽에서 임의의 문자 4개를 제외한 임의의 문자들을 *로 변환해주는 정규식입니다.
정규식이 참 편리한 것 같습니다..
하지만 평소에 잘 사용하지 않기 때문에 저런 정규표현식을 알아도 사용할진 모르겠네요..
그저 감탄만...
'Algorithm' 카테고리의 다른 글
[Java&알고리즘] 제일 작은 수 제거하기 (Level 1) (0) | 2023.03.21 |
---|---|
[Java&알고리즘] 음양 더하기 (Level 1) (0) | 2023.03.21 |
[Java&알고리즘] 나누어 떨어지는 숫자 배열 (Level 1) (1) | 2023.03.10 |
[Java&알고리즘] 서울에서 김서방 찾기 (Level 1) (0) | 2023.03.07 |
[Java&알고리즘] 콜라츠 추측 (Level 1) (0) | 2023.03.06 |
댓글