⛺스파르타코딩클럽

내일배움캠프 16일차 TIL - 개인 공부

junbin2 2024. 5. 7. 09:51

240507

# 오늘 꼭 기억 해야 할 것!

오늘의 학습 

    ●  1. 알고리즘 문제 풀이

    ●  2. 조별 과제

    ●  3. JVM

문제 사이트(프로그래머스) : https://programmers.co.kr/

문제1 ( 정수 제곱근 판별 ) Lv.1 : 87%

임의의 양의 정수 n에 대해, n이 어떠한 양의 정수 x의 제곱인지 아닌지 판단하려 한다.

n이 양의 정수 x의 제곱이라면 x + 1의 제곱을 리턴, n이 양의 정수 x의 제곱이 아니라면 -1을 리턴하는 함수를 만들어라.

 

나의 풀이

class Solution {
    public long solution(long n) {
        long answer = 0;
        while(true) {
        	// 제곱근을 찾았을 때 조건 수행
            if(answer * answer == n) {
                return (answer + 1) * (answer + 1);
            }
            // 제곱근을 찾지 못했고, 정수 n의 범위를 벗어난 경우 -1 return
            if(answer * answer > n) {
                return -1;
            }
            answer++;
        }
    }
}

처음에는 for문을 이용하려고 했지만 반복의 횟수가 불규칙할 것 같다고 판단을 하여 while문으로 바꿔서 했습니다.

첫 if은 제곱근을 찾았을 때 조건을 수행하며 answer * answer 즉, 같은 정수의 곱셈의 값이 임의의 정수 n과 같을 경우

제곱근이 되며 조건 실행 return값으로는 요구사항에 제곱근을 찾을시 x + 1의 제곱을 리턴 수행

두번째 if문 제곱근의 값을 찾지 못하고, 정수 n의 범위를 벗어난 경우 -1 return

 

JVM

1. 컴파일 시점

소스 코드를 작성하고 컴파일러에 의해 컴파일되는 시점

.java를 ByteCode로 바꾸는 시점을 컴파일 시점( 컴파일러가 해줌 )

2. 런타임 시점

프로그램이 실행되고 난 후 시점.

프로그램이 실행되고 사용자와 상호작용하는 동안 발생하는 시간.

프로그램 시작 후 객체가 생성되며 메소드 호출 시점

 

# 오늘의 회고

오늘은 예외처리, Enum클래스와 스프링 기초 제네릭 등등을 복습하였고 알고리즘 문제를 몇개 풀었다.

복습 느낌이라 딱히 쓸 내용이 없어서 TIL이 짧은게 좀 아쉽지만 공부를 열심히 했으므로 오늘도 keep going.