Hayden's Archive

[알고리즘] 프로그래머스 : 문자열 다루기 기본 본문

Algorithm

[알고리즘] 프로그래머스 : 문자열 다루기 기본

_hayden 2020. 5. 15. 23:09

알고리즘 문제 출처 : 프로그래머스 https://programmers.co.kr/learn/courses/30/lessons/12918

 

코딩테스트 연습 - 문자열 다루기 기본

문자열 s의 길이가 4 혹은 6이고, 숫자로만 구성돼있는지 확인해주는 함수, solution을 완성하세요. 예를 들어 s가 a234이면 False를 리턴하고 1234라면 True를 리턴하면 됩니다. 제한 사항 s는 길이 1 이��

programmers.co.kr

 

내가 작성한 코드

방법이 따로 생각나지 않아서 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;
  }
}