728x90
반응형
SMALL

문제 설명

네오와 프로도가 숫자놀이를 하고 있습니다. 네오가 프로도에게 숫자를 건넬 때 일부 자릿수를 영단어로 바꾼 카드를 건네주면 프로도는 원래 숫자를 찾는 게임입니다.다음은 숫자의 일부 자릿수를 영단어로 바꾸는 예시입니다.

  • 1478 → "one4seveneight"
  • 234567 → "23four5six7"
  • 10203 → "1zerotwozero3"

이렇게 숫자의 일부 자릿수가 영단어로 바뀌어졌거나, 혹은 바뀌지 않고 그대로인 문자열 s가 매개변수로 주어집니다. s가 의미하는 원래 숫자를 return 하도록 solution 함수를 완성해주세요.

참고로 각 숫자에 대응되는 영단어는 다음 표와 같습니다.

숫자 영단어

0 zero
1 one
2 two
3 three
4 four
5 five
6 six
7 seven
8 eight
9 nine

제한사항

  • 1 ≤ s의 길이 ≤ 50
  • s가 "zero" 또는 "0"으로 시작하는 경우는 주어지지 않습니다.
  • return 값이 1 이상 2,000,000,000 이하의 정수가 되는 올바른 입력만 s로 주어집니다.

입출력 예

s result

"one4seveneight" 1478
"23four5six7" 234567
"2three45sixseven" 234567
"123" 123

입출력 예 설명

입출력 예 #1

  • 문제 예시와 같습니다.

입출력 예 #2

  • 문제 예시와 같습니다.

입출력 예 #3

  • "three"는 3, "six"는 6, "seven"은 7에 대응되기 때문에 정답은 입출력 예 #2와 같은 234567이 됩니다.
  • 입출력 예 #2와 #3과 같이 같은 정답을 가리키는 문자열이 여러 가지가 나올 수 있습니다.

입출력 예 #4

  • s에는 영단어로 바뀐 부분이 없습니다.

제한시간 안내

  • 정확성 테스트 : 10초
package LV1;
/*
네오와 프로도가 숫자놀이를 하고 있습니다.
네오가 프로도에게 숫자를 건넬 때 일부 자릿수를 영단어로 바꾼 카드를 건네주면 프로도는 원래 숫자를 찾는 게임입니다.
다음은 숫자의 일부 자릿수를 영단어로 바꾸는 예시입니다.
0	zero        z e
1	one         o n
2	two         t w
3	three       t h
4	four        f o
5	five        f i
6	six         s i
7	seven       s e
8	eight       e i
9	nine        n i
 */
import java.util.Arrays;

public class H81301 {
    public static int solution(String s){
        int len = s.length()-1; // 0부터 시작하기에
        String b = "";

        for (int i = 0; i < s.length() ; i++) {
            if (s.charAt(i) == 'o' && i<len){ // 1
                if (s.charAt(i) == 'o' && s.charAt(i+1) == 'n') b+= "1"; // one인 경우! -> o와 n이 들어있으면 1
            }

            if (s.charAt(i) == 't' && i<len){ // 2 3
                if (s.charAt(i) == 't' && s.charAt(i+1) == 'w') b+= "2"; // two인 경우! -> 와 t이 들어있으면 w
                if (s.charAt(i) == 't' && s.charAt(i+1) == 'h') b+= "3"; // three인 경우! -> 와 t이 들어있으면 h
            }

            if (s.charAt(i) == 'f' && i<len){ // 4 5
                if (s.charAt(i) == 'f' && s.charAt(i+1) == 'o') b+= "4"; // four인 경우! -> 와 f이 들어있으면 o
                if (s.charAt(i) == 'f' && s.charAt(i+1) == 'i') b+= "5"; // five인 경우! -> 와 f이 들어있으면 i
            }

            if (s.charAt(i) == 's' && i<len){ // 6 7
                if (s.charAt(i) == 's' && s.charAt(i+1) == 'i') b+= "6"; // six인 경우! -> 와 s이 들어있으면 i
                if (s.charAt(i) == 's' && s.charAt(i+1) == 'e') b+= "7"; // seven인 경우! -> 와 s이 들어있으면 e
            }

            if (s.charAt(i) == 'e' && i<len){ // 8
                if (s.charAt(i) == 'e' && s.charAt(i+1) == '1') b+= "8"; // eight인 경우! -> 와 e이 들어있으면 i
            }

            if (s.charAt(i) == 'n' && i<len){ // 9
                if (s.charAt(i) == 'n' && s.charAt(i+1) == 'i') b+= "9"; // nine인 경우! -> 와 n이 들어있으면 i
            }

            if(s.charAt(i)=='z') b+="0"; // 0
            if('0'<=s.charAt(i)&&s.charAt(i)<='9') b+=s.charAt(i)-48;   // 값이 숫자인 경우
            }
        
        int answer = Integer.parseInt(b); //  구한 값을 int형을 변환 -> 결과적으로 숫자로 만들어야하기 떄문
        return answer;
    }
    public static void main(String[] args){
        String s = Arrays.toString(new String[]{"one4seveneight"});
        System.out.println(solution(s));
    }
}

하드코딩…..

728x90
반응형
LIST

'알고리즘 > 프로그래머스 JAVA LV.1' 카테고리의 다른 글

약수의 개수와 덧셈  (0) 2023.01.30
시저 암호  (1) 2023.01.30
소수 만들기  (0) 2023.01.30
예산  (0) 2023.01.30
약수의 합  (0) 2023.01.30

+ Recent posts