다음 큰 숫자 Lv. 2 | 링크 https://school.programmers.co.kr/learn/courses/30/lessons/12911 자연수 n이 주어졌을 때, n의 다음 큰 숫자는 다음과 같이 정의 합니다. 조건 1. n의 다음 큰 숫자는 n보다 큰 자연수 입니다. 조건 2. n의 다음 큰 숫자와 n은 2진수로 변환했을 때 1의 갯수가 같습니다. 조건 3. n의 다음 큰 숫자는 조건 1, 2를 만족하는 수 중 가장 작은 수 입니다. 예를 들어서 78(1001110)의 다음 큰 숫자는 83(1010011)입니다. 자연수 n이 매개변수로 주어질 때, n의 다음 큰 숫자를 return 하는 solution 함수를 완성해주세요. 제한 사항 n은 1,000,000 이하의 자연수 입니다. 입출력 예..
자바 가상 머신(JVM, Java Virtual Machine) 이란? 자바 가상 머신(JVM, Java Virtual Machine)은 자바 프로그램 실행환경을 만들어주는 소프트웨어이다. 이 포스트와 함께 다루고 싶지만 내용이 너무 길어져 나누어 작성하게 되었다. 불편하시더라도 자바 가상 머신에 대해서는 아래 포스트를 참고 부탁드립니다! 자바 가상 머신 내 메모리 구조만 알고 있어도 물론 좋겠지만 메모리 구조를 알기 전에 JVM이 뭔지 제대로 알면 더 좋을 것 같다. 숲이 아닌 나무를 보다 보면 결국 나중에는 나무만 알고 전체적인 숲의 모습을 알기 힘들어지는 법. (내가 이 블로그를 쓰고 있는 이유 😂) 자바 가상 머신 (JVM, Java Virtual Machine)의 구조와 동작방식 자바 가상 머신..
올바른 괄호 Lv. 2 | 링크 https://school.programmers.co.kr/learn/courses/30/lessons/12924 Finn은 요즘 수학공부에 빠져 있습니다. 수학 공부를 하던 Finn은 자연수 n을 연속한 자연수들로 표현하는 방법이 여러 개라는 사실을 알게 되었습니다. 예를 들어 15는 다음과 같이 4가지로 표현할 수 있습니다. 1 + 2 + 3 + 4 + 5 = 15 4 + 5 + 6 = 15 7 + 8 = 15 15 = 15 자연수 n이 매개변수로 주어질 때, 연속된 자연수들로 n을 표현하는 방법의 수를 return하는 solution를 완성해 주세요. 제한 사항 n은 10,000 이하의 자연수 입니다. 입출력 예 입력 예시 출력 예시 15 4 입출력 예 설명 입출력 ..
이진 변환 반복하기 Lv. 2 | 링크 https://school.programmers.co.kr/learn/courses/30/lessons/70129 0과 1로 이루어진 어떤 문자열 x에 대한 이진 변환을 다음과 같이 정의합니다. x의 모든 0을 제거합니다. x의 길이를 c라고 하면, x를 "c를 2진법으로 표현한 문자열"로 바꿉니다. 예를 들어, x = "0111010"이라면, x에 이진 변환을 가하면 x = "0111010" -> "1111" -> "100" 이 됩니다. 0과 1로 이루어진 문자열 s가 매개변수로 주어집니다. s가 "1"이 될 때까지 계속해서 s에 이진 변환을 가했을 때, 이진 변환의 횟수와 변환 과정에서 제거된 모든 0의 개수를 각각 배열에 담아 return 하도록 solutio..
올바른 괄호 Lv. 2 | 링크 https://school.programmers.co.kr/learn/courses/30/lessons/12909 괄호가 바르게 짝지어졌다는 것은 '(' 문자로 열렸으면 반드시 짝지어서 ')' 문자로 닫혀야 한다는 뜻입니다. 예를 들어 "()()" 또는 "(())()" 는 올바른 괄호입니다. ")()(" 또는 "(()(" 는 올바르지 않은 괄호입니다. '(' 또는 ')' 로만 이루어진 문자열 s가 주어졌을 때, 문자열 s가 올바른 괄호이면 true를 return 하고, 올바르지 않은 괄호이면 false를 return 하는 solution 함수를 완성해 주세요. 제한 사항 문자열 s의 길이 : 100,000 이하의 자연수 문자열 s는 '(' 또는 ')' 로만 이루어져 있습니..