베어_
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)

블로그 메뉴

    공지사항

    인기 글

    태그

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

    최근 댓글

    최근 글

    티스토리

    hELLO · Designed By 정상우.
    베어_

    TechBear

    알고리즘/LeetCode

    [LeetCode] Longest Consecutive Sequence (Java)

    2023. 7. 17. 22:06

    ✉️문제

    https://leetcode.com/problems/longest-consecutive-sequence/description/

     

    Longest Consecutive Sequence - LeetCode

    Can you solve this real interview question? Longest Consecutive Sequence - Given an unsorted array of integers nums, return the length of the longest consecutive elements sequence. You must write an algorithm that runs in O(n) time.   Example 1: Input:

    leetcode.com

     

    📝 접근

    Set 배열에 모든 배열 요소를 집어넣은 다음에 연속적인 수가 있는지 비교한다.

     

    🗝 문제풀이

    이번에는 코드의 수정 부분을 기억하기 위해 시도한 접근 방법도 같이 기록해둔다.

    [첫 번째 시도 - TLE]

       왜 TLE가 나는지  [100, 4, 200, 1, 3, 2] 테스트 케이스를 가지고 생각해보자. 

    n = 4일 때 while문이 3번 반복된다. 

    n = 3일 때 while문이 2번 반복된다. 

    만약 배열의 모든 수가 연속적인 수라면 최악의 경우 O(N^2)이 된다. [1,2,3,4,5,6,7,8,9,10] 을 가지고 직접 해보자 !

    public int longestConsecutive(int[] nums) {
        Set<Integer> set = new HashSet<>();
        for(int n : nums) {
            set.add(n);
        }
    
    
        int answer = 0;
        for(int n : set) {
            int length = 1;
            if(set.contains(n - 1)) {
                while(set.contains(n - 1)) {
                    length++;
                    n--;
                }
            }   
            answer = Math.max(answer, length);         
        }
    
        return answer;
    }

     

    이를 해결하기 위해 코드를 살짝 변경하였다.

    public int longestConsecutive(int[] nums) {
        Set<Integer> set = new HashSet<>();
        for(int n : nums) {
            set.add(n);
        }
    
    
        int answer = 0;
        for(int n : set) {
            int length = 1;
            /* 바뀐 부분 시작 */
            if(!set.contains(n - 1)) { 
                while(set.contains(n + length)) {
                    length++;
                }
    
                answer = Math.max(answer, length);         
            }   
            /* 바뀐 부분 끝 */
        }
    
        return answer;
    }
    저작자표시 비영리 변경금지 (새창열림)
      '알고리즘/LeetCode' 카테고리의 다른 글
      • [LeetCode] Linked List Cycle (Java)
      • [LeetCode] Reverse Linked List (Java)
      • [LeetCode] House Robber II (Java)
      • [LeetCode] Combination Sum IV (Java)
      베어_
      베어_
      Today I learned | 문제를 해결하는 개발자

      티스토리툴바