프로그래머스 - 문자열 다루기 기본(자바)

KDG: First things first!·2024년 7월 1일
0

프로그래머스

목록 보기
2/18

문제 링크: https://school.programmers.co.kr/learn/courses/30/lessons/12918?language=java


문제 설명

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


제한 사항

  • s는 길이 1 이상, 길이 8 이하인 문자열입니다.
  • s는 영문 알파벳 대소문자 또는 0부터 9까지 숫자로 이루어져 있습니다


입출력 예

sreturn
"a234"false
"1234"true



내 풀이

import java.util.Arrays;

class Solution {
    public boolean solution(String s) {

        char[] charList = s.toCharArray();  // 문자열을 문자 배열로 변환

        if (charList.length != 4 && charList.length != 6) return false;  // 문자열 길이가 4 또는 6이 아니면 false

        for (char c : charList) {  
            if (!Character.isDigit(c)) return false;  // 문자열의 각 문자가 숫자가 아니면 false
        }
        return true;  // 문자열이 숫자로만 이루어져 있으면 true

    }
}

toCharArray(): 문자열의 각 자리를 문자(char)로 변환 후 배열에 저장하는 메서드

Character.isDigit(): 해당 문자가 숫자 형태인지 boolean값을 반환해주는 메서드



다른 사람의 풀이(정규식 이용)


정규식 1

import java.util.*;

class Solution {
    public boolean solution(String s) {
        // \\d{4}는 정확히 4개의 숫자를 의미하고 |는 OR 연산자이며 \\d{6}는 정확히 6개의 숫자를 의미
        return s.matches("\\d{4}|\\d{6}");
    }
}

matches(): String 클래스의 메서드로 문자열이 정규 표현식과 일치하는지를 확인하는 메서드

\\d: 자바에서 숫자를 판별하는 정규 표현식
x{n}: x가 n번 반복


정규식 2

import java.util.*;

class Solution {
    public boolean solution(String s) {
    // 0~9까지 숫자가 4번 반복 또는 6번 반복
        return s.matches("[0-9]{4}|[0-9]{6}");
        
    }
}

[0-9]: 정규 표현식에서 숫자 하나를 나타내는 문자 클래스이다. 0부터 9까지의 모든 숫자를 포함한다.


정규식 3

import java.util.*;

class Solution {
  public boolean solution(String s) {
        if (s.length() == 4 || s.length() == 6) return s.matches("(^[0-9]*$)");
        return false;
  }
}

^x: 문자열의 시작. 문자열이 x로 시작되어야 함을 의미한다.
*x: 해당 문자의 반복 여부를 표현하며 x 문자가 0번 또는 그 이상 반복됨을 의미
x$: 문자열의 끝. 문자열이 x로 종료되어야 한다.

profile
알고리즘, 자료구조 블로그: https://gyun97.github.io/

0개의 댓글