[CodingTest] 짝수와 홀수

hye·2023년 2월 13일
0

AlgorithmTest

목록 보기
10/95

📖 Exam

문제 설명

문자열 s를 숫자로 변환한 결과를 반환하는 함수, solution을 완성하세요.

제한 조건

  • s의 길이는 1 이상 5이하입니다.
  • s의 맨앞에는 부호(+, -)가 올 수 있습니다.
  • s는 부호와 숫자로만 이루어져있습니다.
  • s는 "0"으로 시작하지 않습니다.

입출력 예

예를들어 str이 "1234"이면 1234를 반환하고, "-1234"이면 -1234를 반환하면 됩니다.
str은 부호(+,-)와 숫자로만 구성되어 있고, 잘못된 값이 입력되는 경우는 없습니다.


✍ Answer

    public int solution(String s) {
        return Integer.parseInt(s);
    }

💡 Realization

  • 풀면서 이게 문제...? 라고 생각했는데
    처음에 리턴값을 Integer.valueOf() 로 표현했는데 일반 정수 표현이기때문에 Integer.parseInt()이 맞다고 생각된다.

  • 프로그래머스 문제 풀이를 보니 parseInt 자체 메서드를 만든 분 계시더라. 존경...

public class StrToInt {
    public int getStrToInt(String str) {
            boolean Sign = true;
            int result = 0;

      for (int i = 0; i < str.length(); i++) {
                char ch = str.charAt(i);
                if (ch == '-')
                    Sign = false;
                else if(ch !='+')
                    result = result * 10 + (ch - '0');
            }
            return Sign?1:-1 * result;
    }
    
    public static void main(String args[]) {
        StrToInt strToInt = new StrToInt();
        System.out.println(strToInt.getStrToInt("-1234"));
    }
}

부호체크는 for문 밖에서 한 번만 체크해주는게 좋다. (참고)

문자형(char)을 사칙연산 할 때는 각 문자에 부여된 유니코드 값으로 계산이 이뤄집니다. ( ex) 0의 유니코드 값은 48 ) 그런데 숫자가 1씩 커질 때마다 유니코드 값도 1씩 커지기 때문에 숫자가 담긴 문자형끼리 뺄샘을 하면 실제 숫자로 계산했을 때와 같은 값이 나오게 됩니다.

참고사이트 : https://school.programmers.co.kr/learn/courses/30/lessons/12925/solution_groups?language=java

profile
Junior Backend Developer

0개의 댓글