waveofmymind
기록하는 습관
waveofmymind
전체 방문자
오늘
어제
  • 분류 전체보기 (124)
    • 📝 정리 (5)
    • 🌊TIL (9)
    • 💻CS (1)
      • 자료구조 (1)
    • 📙Language (9)
      • ☕Java (6)
      • 🤖Kotlin (3)
    • 🍃Spring (28)
    • 👨🏻‍💻알고리즘 (67)
      • 프로그래머스 (59)
      • 백준 (3)
    • 👷DevOps (4)
      • 🐳Docker (2)
      • 🤵Jenkins (1)

블로그 메뉴

  • 홈
  • Spring
  • Java
  • 알고리즘

공지사항

인기 글

태그

  • 챗GPT
  • 통합테스트
  • Connection
  • til
  • 트랜잭션
  • kotlin
  • Open AI
  • 코틀린
  • 힙
  • 스프링
  • 완전탐색
  • kotest
  • 스택
  • JDBC
  • SpringAOP
  • 스프링 시큐리티
  • BFS
  • resultset
  • spring boot
  • 스프링 부트
  • sql
  • chat GPT
  • 트랜잭션 전파
  • 다이나믹 프로그래밍
  • AOP
  • Spring Security
  • mybatis
  • spring
  • LeetCode
  • CORS

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
waveofmymind

기록하는 습관

[프로그래머스] Lv1. 가장 가까운 같은 글자
👨🏻‍💻알고리즘/프로그래머스

[프로그래머스] Lv1. 가장 가까운 같은 글자

2023. 1. 30. 23:08

코드

class Solution {
    public int[] solution(String s) {
        int[] answer = new int[s.length()];
        answer[0] = -1;
      
        for (int i = 1; i < s.length();i++) {
            int x = s.lastIndexOf(s.substring(i,i+1),i-1);
            if (x != -1) {
                answer[i] = i-x;
            } else {
                answer[i] = x;
            }
        }
        return answer;
    }
}

풀이

  • 가장 첫 글자는 무조건 -1이다.
  • lastIndexOf()를 사용하면, i-1 인덱스를 기준으로 s.substring(i,i+1)이 있는지 없는지를 확인한다.
  • x가 -1이면 없다는 것이므로 answer[i]에 x를 넣는다
  • x가 -1이 아닐경우 1-x를 넣는다.

 

'👨🏻‍💻알고리즘 > 프로그래머스' 카테고리의 다른 글

[프로그래머스] Lv3. 단속 카메라  (0) 2023.01.31
[프로그래머스] Lv3. 등굣길  (0) 2023.01.31
[프로그래머스] Lv1. 푸드 파이트 대회  (0) 2023.01.30
[프로그래머스] Lv2. 모음사전  (0) 2023.01.30
[프로그래머스] Lv3. 단어 변환  (0) 2023.01.29
    '👨🏻‍💻알고리즘/프로그래머스' 카테고리의 다른 글
    • [프로그래머스] Lv3. 단속 카메라
    • [프로그래머스] Lv3. 등굣길
    • [프로그래머스] Lv1. 푸드 파이트 대회
    • [프로그래머스] Lv2. 모음사전
    waveofmymind
    waveofmymind

    티스토리툴바