반응형
프로그래머스의 알고리즘 문제 및 풀이에 대해 차근차근 포스팅하려합니다.
저도 초보자이기도하고 알고리즘에 쉽게 다가갈 수 없는 부분들이 많기 때문에
최대한 알기 쉽게 정리해보려하고 알고리즘을 어려워하는 분들에게 도움이 되었으면 합니다.
많이 공유되고 토론이 될 수 있는 공간이 되었으면 좋겠습니다.
환경
언어 : 자바
단계 : 레벨 1단계 (입문자용)
정답률 : 78%
제목
문자열 다루기 기본
문제 설명 및 코드
문자열 s의 길이가 4 혹은 6이고, 숫자로만 구성돼있는지 확인해주는 함수, solution을 완성하세요. 예를 들어 s가 "a234"이면 False를 리턴하고 "1234"라면 True를 리턴하면 됩니다.
- s는 길이 1 이상, 길이 8 이하인 문자열입니다.
- s는 영문 알파벳 대소문자 또는 0부터 9까지 숫자로 이루어져 있습니다.
1
2
3
4
5
6
7
|
class Solution {
public boolean solution(String s) {
boolean answer = true;
return answer;
}
}
|
cs |
입출력 예
s | return |
"a234" | false |
"1234" | true |
반응형
문제 정답 코드
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
class Solution {
public boolean solution(String s) {
boolean answer = false;
if(s.length() == 4 || s.length() == 6){
for(int a=0; a<s.length(); a++){
int chk = s.charAt(a);
answer = (48<=chk && chk<=57) ? true : false;
if(!answer) break;
}
}
return answer;
}
}
|
cs |
저는 아스키코드를 이용한 활용 방법으로 풀이하였습니다.
길이가 4또는 6이라면
s의 길이만큼 반복문을 돌려주면서
charAt메서드로 변환 후 int로 변경해줍니다.
아스키코드값의 0부터 9의 정수는 48부터 57까지 아스키코드값이므로
이 사이에 들어간다면 true 아니면 false를 해줍니다.
false라면 반복문에서 나와 바로 return value해줍니다.
다른사람 풀이
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
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;
}
}
|
cs |
예외를 이용한 방법으로 문자열을 숫자로 변경한뒤
숫자면 true 아니라면 false를 이용한 풀이입니다.
1
2
3
4
5
6
7
8
|
import java.util.*;
class Solution {
public boolean solution(String s) {
if (s.length() == 4 || s.length() == 6) return s.matches("(^[0-9]*$)");
return false;
}
}
|
cs |
이 또한 비슷하지만 정규식을 이용한 풀이 방법입니다.
반응형
'Algorithm' 카테고리의 다른 글
[Java&알고리즘] 행렬의 덧셈 (Level 1) (0) | 2023.03.31 |
---|---|
[Java&알고리즘] 부족한 금액 계산하기 (Level 1) (0) | 2023.03.29 |
[Java&알고리즘] 약수의 개수와 덧셈 (Level 1) (0) | 2023.03.28 |
[Java&알고리즘] 문자열 내림차순으로 배치하기 (Level 1) (0) | 2023.03.24 |
[Java&알고리즘] 가운데 글자 가져오기 (Level 1) (1) | 2023.03.23 |
댓글