Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- candies
- Recursion: Davis' Staircase
- 백준
- 알고리즘
- 피보나치 함수
- Special String Again
- Roads and Libraries
- 격파르타 후기
- Reverse Shuffle Merge
- programmers
- Max Array Sum
- 머신러닝
- Find the nearest clone
- 매칭점수
- 코딩테스트
- 해커랭크
- BFS: Shortest Reach in a Graph
- DFS: Connected Cell in a Grid
- hackerrank
- 프로그래머스
- python
- 야근지수
- 격파르타 합격후기
- 구슬탈출2
- 파이썬
- Algorithm
- Interview Preparation Kit
- 격파르타 장점
- Common Child
- [sqld]자격증합격
Archives
- Today
- Total
Archive
[Hackerrank] [Medium] Special String Again 본문
https://www.hackerrank.com/challenges/special-palindrome-again/problem
풀이
- 입력으로 문자열 길이, string이 주어졌을 때, 다음 조건에 만족하는 substring 개수를 구하는 문제
- substring에 포함된 모든 문자가 같은 경우. ex) aaa
- substring의 가운데 하나를 제외한 양 옆의 모든 문자가 같은 경우. ex) aadaa
- ex) s = mnonopoo
- special substrings = {m, n, o, n, o, p, o, o, non, ono, opo, oo} 12개
- 입력받은 string에서 문자의 빈도 수를 순서대로 count해서 tuple로 저장.
- ex) s = mnonopoo => [(m, 1), (n, 1), (o, 1), (n, 1), (o, 1), (p, 1), (o, 2)]
- 동일한 문자가 연속으로 나왔을 경우의 special substring 개수를 구해서 더해줌.
- ex) s = ooo => [(o, 3)] => {o, o, o, oo, oo, ooo} 6가지. 공식 : n * (n + 1) // 2
- sliding window 방식으로, tuple이 저장된 리스트를 3개씩 훑어보면서 special substring 조건에 만족하는지 검사.
- sliding window 크기는 3으로 하고, 첫 번째 tuple의 string과 세 번째 tuple의 string이 같아야 하고, 두 번째 문자의 빈도 수가 1이어야 함.
- 조건을 만족하면 양 옆 문자열의 빈도 수가 작은 경우를 더해줌.
- s = aabaaa => [(a, 2) , (b, 1), (a, 3)] => 두 번째 조건의 경우 2를 더해줌
- aabaa, aba 두 가지 경우가 있음.
def substrCount(n, s):
char_cnt = []
count = 0
cur = None
for i in range(n):
if s[i] == cur:
count += 1
else:
if cur is not None:
l.append((cur, count))
cur = s[i]
count = 1
l.append((cur, count))
ans = 0
# 연속된 문자에서 special substring 개수 구하기
for i in l:
ans += (i[1] * (i[1] + 1)) // 2
# sliding window 크기 3으로 전체를 훑어봄.
for i in range(1, len(l) - 1):
# 첫 번째 tuple의 string = 세 번째 tuple의 string and 두 번째 tuple의 문자 수가 1
if l[i - 1][0] == l[i + 1][0] and l[i][1] == 1:
# 양쪽 string의 빈도 수가 적은 경우를 전체에 더해줌
ans += min(l[i - 1][1], l[i + 1][1])
return ans
'공부 > Algorithm' 카테고리의 다른 글
[Hackerrank] [Hard] Reverse Shuffle Merge (0) | 2020.08.31 |
---|---|
[Hackerrank] [Medium] Common Child (0) | 2020.08.28 |
[Hackerrank] [Medium] Sherlock and the Valid String (0) | 2020.08.27 |
[Hackerrank] [Hard] Merge Sort: Counting Inversions (0) | 2020.08.25 |
[Hackerrank] [Medium] Fraudulent Activity Notifications (0) | 2020.08.24 |
Comments