베어_
TechBear
베어_
전체 방문자
오늘
어제
  • 분류 전체보기 (336)
    • Spring (33)
      • 개념 (13)
      • Security (5)
      • 실습 (1)
      • 토비 스프링 (11)
    • JPA (6)
    • 프로젝트 기록 (24)
    • DB (13)
    • JAVA (18)
    • 알고리즘 (50)
      • 유형정리 (8)
      • Baekjoon (21)
      • LeetCode (18)
    • 디자인패턴 (0)
    • 개발서적 (79)
      • Effective Java (78)
      • 객체지향의 사실과 오해 (1)
    • 독후감 (4)
    • 보안 (2)
    • 운영체제(OS) (53)
      • 공룡책 (53)
    • 컴퓨터 네트워크 (28)
      • 컴퓨터 네트워크 하향식 접근 (23)
    • 자료구조 (1)
    • DevOps (2)
    • 앱 개발 (20)
      • 안드로이드 스튜디오 (20)

블로그 메뉴

    공지사항

    인기 글

    태그

    • 코드업
    • dfs
    • 자바8
    • 알고리즘
    • jpa
    • C++
    • Spring
    • 스레드
    • java
    • BFS
    • 데이터베이스
    • leetcode
    • 백준
    • 이펙티브자바
    • 스프링
    • 운영체제
    • 자바
    • 스프링시큐리티
    • 토비스프링
    • 함수형인터페이스

    최근 댓글

    최근 글

    티스토리

    hELLO · Designed By 정상우.
    베어_

    TechBear

    알고리즘/유형정리

    [알고리즘] 카데인 알고리즘

    2023. 6. 24. 21:41

    카데인 알고리즘

    DP(Dynamic Programming)기법 중 하나로 연속적인 수의 나열에서 최대합 또는 곱을 구하는데 사용된다.

    아이디어

    [-2, 3, -1, 2]의 숫자가 있다. 이 배열에서 최대 부분합을 구해보자.

    [-2, 3, -1, 2]의 최대 부분합을 구하기 위해서는 [-2, 3, -1]의 최대 부분합을 알아야 한다. 이를 알기 위해서는 [-2, 3]의 최대 부분합을 알아야 한다. 마지막으로 [-2]의 최대 부분합을 알아야 한다. 이렇게 큰 집합을 작은 부분 집합으로 나누어서 풀이해 정복하는 DP 기법을 이용한다.

    슈도 코드

    function kadaneAlgorithm(nums) {
        var curSum = 0, max = INT_MIN
        // i = 1 부터 nums.length - 1까지 반복
        i = 1 to nums.length - 1 {
            curSum = Max(curSum, curSum + nums[i]);
            max = Max(max, curSum);
        }
    }

    관련 문제

    1. Best Time to Buy and Sell Stock
    2. Product of Array Except Self
    3. Maximum SubArray
    4. Maximum Product SubArray
    저작자표시 비영리 변경금지 (새창열림)
      '알고리즘/유형정리' 카테고리의 다른 글
      • [알고리즘] 버킷 정렬
      • [알고리즘] 소수 알고리즘
      • [알고리즘] 약수 알고리즘
      • [알고리즘] 동전 교환 알고리즘
      베어_
      베어_
      Today I learned | 문제를 해결하는 개발자

      티스토리툴바