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

블로그 메뉴

    공지사항

    인기 글

    태그

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

    최근 댓글

    최근 글

    티스토리

    hELLO · Designed By 정상우.
    베어_

    TechBear

    JAVA

    [LeetCode] Longest Repeating Character Replacement (Java)

    2023. 8. 3. 09:23

    ✉️문제

    https://leetcode.com/problems/longest-repeating-character-replacement/description/

     

    📝 접근

    1. 투 포인터 알고리즘을 기본적으로 이용한다. (left, right 포인터)
    2. right포인터를 오른쪽으로 이동시키면서 가장 빈번하게 나타난 알파벳의 개수를 기억한다. 
      • (right - left + 1 - maxFrequency)는 uppercase로 바꾼 횟수를 의미한다.
    3. 만약 right - left + 1 - maxFrequency > k 이면 left를 증가시킨다. 
      • left를 증가시킬 때 마다 maxFrequecy를 감소시킬 필요는 없다.
      • 답은 가장 긴 길이를 구하는 것이며 maxF가 감소될 때 정답이 갱신될 수 없다.

     

    🗝 문제풀이

    class Solution {
        public int characterReplacement(String s, int k) {
            int[] ch = new int['Z' - 'A' + 1];
    
            int max = Integer.MIN_VALUE;
            int maxLen = 0;
            for(int left = 0, right = 0; right < s.length(); right++) {
                int index = s.charAt(right) - 'A';
                ch[index]++;
                max = Math.max(max, ch[index]);
                while(right - left + 1 - max > k) {
                    ch[s.charAt(left) - 'A']--;
                    left++;
                }
    
                maxLen = Math.max(maxLen, right - left + 1);
                // System.out.println(max);
            }
    
            return maxLen;
        }
    }
    저작자표시 비영리 변경금지 (새창열림)
      'JAVA' 카테고리의 다른 글
      • [LeetCode] Pacific Atlantic Water Flow (Java)
      • [Java] 람다와 스트림
      • [Java] Volatile 키워드
      • [Java] 쓰레드의 동기화
      베어_
      베어_
      Today I learned | 문제를 해결하는 개발자

      티스토리툴바