Hayden's Archive
[알고리즘] 프로그래머스 : 문자열 다루기 기본 본문
알고리즘 문제 출처 : 프로그래머스 https://programmers.co.kr/learn/courses/30/lessons/12918
내가 작성한 코드
방법이 따로 생각나지 않아서 s가 8이하인 문자열이라는 제한 사항을 보고 그냥 char형 배열을 만들고 문자열을 charAt()로 한 글자씩 뽑아내서 비교대조하였다.
class Solution {
public boolean solution(String s) {
boolean answer = false;
int checkNum = 0;
char[] check = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9'};
for(int i = 0; i < s.length(); i++) {
for(char c : check) {
if(s.length() != 4 && s.length() !=6) break;
if(s.charAt(i) == c) {
checkNum += 1;
}
}
}
if(checkNum == s.length()) answer = true;
return answer;
}
}
다른 사람들의 코드
이렇게 간단한 걸 왜 생각을 못했을까 싶다. 간단히 int형으로 바꾸고 예외가 일어난다면 문자가 끼어있는 거니까 자연스럽게 false 처리하면 되는데 이렇게 쉬운 걸 막상 코드 짤 때는 떠올리지 못했다는 점이 아쉽다.
class Solution {
public boolean solution(String s) {
if(s.length() == 4 || s.length() == 6){
try{
int x = Integer.parseInt(s);
return true;
} catch(NumberFormatException e){
return false;
}
}
else return false;
}
}
정규표현식으로도 비교가 가능하다. 이 코드 덕분에 정규표현식의 쓰임새를 좀 더 알게 됨. ( 참고 : https://m.post.naver.com/viewer/postView.nhn?volumeNo=7399012&memberNo=30800755&vType=VERTICAL )
import java.util.*;
class Solution {
public boolean solution(String s) {
if (s.length() == 4 || s.length() == 6) return s.matches("(^[0-9]*$)");
return false;
}
}