본문 바로가기

전체 글

(430)
[알고리즘] 자릿수 더하기 (Java 예제) 1. 자바로 정수 자릿수 더하기나누기 연산자(/)/ 연산자는 정수 나누기를 수행하여 나머지를 제외한 값을 반환합니다. 예: 2345 / 10 = 234나머지 연산자 (%)나누었을 때 나누어 떨어지지 않는 값을 반환합니다.예: 2345 % 10 = 5 (2345를 10으로 나누었을 때의 나머지)예제 코드:class Solution { public int solution(int n) { int result = 0; // n이 0이 될 때까지 반복하기 while (n > 0) { // result에 n % 10을 더하기 result += n % 10; // 예) 2345 % 10 = 5 // n..
[프로그래머스 (Oracle)] 오랜 기간 보호한 동물(1) 힌트LEFT OUTER JOIN 사용:ANIMAL_INS 테이블의 모든 레코드와 ANIMAL_OUTS 테이블의 일치하는 레코드를 결합합니다.이 때, ANIMAL_OUTS에 일치하는 레코드가 없는 경우에도 ANIMAL_INS의 레코드는 유지됩니다.조건 필터링:WHERE 절에서 O.DATETIME IS NULL 조건을 사용하여, ANIMAL_OUTS에 없는 동물만 선택합니다.즉, 아직 입양되지 않은 동물의 정보를 찾고 있습니다.정렬 및 제한:ORDER BY I.DATETIME으로 입소 날짜를 기준으로 오름차순 정렬합니다.LIMIT 3을 사용하여 결과를 3개로 제한합니다.정답은 더보기 클릭더보기더보기SELECT I.NAME, I.DATETIME -- 동물의 이름과 입소 날짜 선택 FROM ANIMAL_IN..
[프로그래머스 (Kotlin)] 배열 만들기 1 배열을 생성하는 여러가지 방법 1. IntArray(크기) {요소 추가}class Solution { fun solution(n: Int, k: Int): IntArray { // IntArray(n / k): n을 k로 나눈 크기의 배열 생성 // { i -> (i + 1) * k }: i는 0부터 시작해서 배열 크기 - 1까지 증가하며, 각 인덱스에 (i + 1) * k 값을 할당 // 즉, k의 배수를 배열에 차례대로 추가 var result = IntArray(n / k) { i -> (i + 1) * k } return result }  2. 범위 연산자와 toList() 사용class Solution { ..
[Kotlin] 변수 선언 코틀린은 자바 플랫폼에서 실행하는 프로그래밍 언어입니다.그렇기에 자바와 비슷한 점이 많습니다. 변수 선언 기본 형태var/val 변수명: 변수타입 = 초기화예시:var number: Int = 0var name: String = "홍길동"var isAble: Boolean = truevar email: String? = nullvar avg: Double = 0.0   자바와 차이점var / val 키워드가장 큰 차이점 중 하나는 var와 val 키워드를 사용하는 것입니다.var: variable의 약자로, 읽기/쓰기(read/write)가 가능한 변수를 의미합니다.val: valuable의 약자로, 읽기 전용(read-only) 변수를 의미하며, 자바에서의 final 키워드와 유사합니다.var age:..
[프로그래머스] 연속된 부분 수열의 합 힌트목표 합을 찾기:주어진 배열에서 연속된 부분 배열의 합이 k가 되는 구간을 찾아야 합니다.시작점과 끝점 두 개의 포인터를 사용하여 배열을 탐색하며, 포인터 사이의 값들의 합이 k와 같은지 확인합니다.이동 방식:초기에는 배열의 시작에서 끝까지 포인터를 이동하면서 합계를 계산합니다.만약 현재 합이 k보다 크다면 시작 포인터를 앞으로 이동시켜 구간을 줄입니다.합이 정확히 k가 되면 해당 구간을 기록하고, 더 짧은 구간이 있을 경우 그것으로 업데이트합니다.최적화 방법:각 구간에서의 합을 실시간으로 유지하며, 불필요한 연산을 줄이기 위해 더 짧은 구간이 발견될 때만 결과를 업데이트합니다.탐색이 끝날 때까지 가장 짧은 구간을 찾아냅니다. 정답은 더보기 클릭더보기class Solution { public i..
[프로그래머스] 큰 수 만들기 코드 힌트큰 수 만들기:주어진 숫자에서 일부 자릿수를 제거해 가능한 가장 큰 숫자를 만들어야 합니다.제거할 자릿수는 이미 고정되어 있기 때문에, 각 자릿수에서 최선의 선택을 해야 합니다.탐색 방법:각 자리에서 남은 숫자들 중에서 가장 큰 숫자를 선택합니다.선택한 숫자의 다음 위치부터 다시 탐색을 시작하여, 그 뒤에서 또 가장 큰 숫자를 찾습니다.범위 관리:현재 자리를 결정할 때, 앞으로 선택할 자리를 고려하여 탐색 범위를 설정합니다.한 번 선택된 숫자는 다시 선택하지 않도록 다음 선택할 범위를 줄여 나가야 합니다.최적화 아이디어:이미 선택된 숫자보다 더 작은 숫자는 무시하고, 그 다음 탐색부터 빠르게 넘어가면서 최종 큰 수를 만들어냅니다. 정답은 더보기 클릭더보기class Solution { pub..
[수학] 다양한 함수 함수(Function)란?함수는 입력을 결정하면 출력이 하나로 고정되는 관계를 말합니다. 즉, 어떤 수를 넣었을 때 이에 대응하는 수가 하나로 결정되어 출력되는 과정을 함수라고 부릅니다. 마치 기계처럼 입력값에 따라 일정한 결과를 반환하는 것입니다.수학적 예시: y=ax+b 여기서 a는 기울기, b는 y절편을 의미합니다.자바 예시:public int max(int a, int b) { if (a > b) return a; return b;}   이 함수는 두 숫자 중 더 큰 값을 반환합니다.지수 함수(Exponential Function)란?지수 함수는 y=ax의 형태를 가지며, 여기서 a는 '밑(base)'이고 x는 '지수(exponent)'입니다.지수 함수의 특징단조 증가: 지수 함수는 x..
[백준] 균형잡힌 세상 (4949번) 코드 힌트:입력 처리사용자는 여러 줄의 문자열을 입력합니다. 입력된 문자열이 .으로 시작하지 않을 때까지 반복적으로 처리합니다.input.replaceAll("[a-zA-Z.]*", "")와 input.replaceAll("\\s++", "")를 통해 괄호 외의 문자와 공백을 제거한 후 문자열을 처리합니다.스택을 이용한 괄호 짝 검사각 문자열을 순회하며 열린 괄호 ( 또는 [는 스택에 추가합니다.닫힌 괄호 ) 또는 ]를 만날 경우, 스택의 최상단에 있는 열린 괄호와 짝이 맞는지 확인합니다.짝이 맞으면 스택에서 제거하고, 그렇지 않으면 isAble을 false로 설정해 잘못된 괄호 짝임을 표시합니다.결과 출력문자열 순회가 끝난 후, isAble이 true이고 스택이 비어있으면 괄호가 올바르게 닫혔으므로 "..