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
- 발더스3
- 누룽지소금빵
- 바질토마토뭐시기
- 맛집
- 눈알빠지겠네
- 코테
- 토이프로젝트
- LeetCode
- 밥무하마드
- 서울제빵소
- 알고리즘테스트
- 뜨아거
- 게임
- DIY
- javascript
- 나쫌
- 취미
- 메일우유
- 버즈2프로
- 코딩테스트
- 롱라이플
- 발더스모드
- 발더스게이트
- 제프딕슨
- 노노그램
- 박주영판사
- 미앤아이
- 송리단
- 우리시대의역설
- 메탈퍼즐
Archives
- Today
- Total
.Zzumbong
[leetCode/JS] 696. Count Binary Substrings 본문
문제 설명
Given a binary string s
, return the number of non-empty substrings that have the same number of 0
's and 1
's, and all the 0
's and all the 1
's in these substrings are grouped consecutively.
Substrings that occur multiple times are counted the number of times they occur.
입출력 예
Example 1:
Input: s = "00110011"
Output: 6
Explanation: There are 6 substrings that have equal number of consecutive 1's and 0's: "0011", "01", "1100", "10", "0011", and "01".
Notice that some of these substrings repeat and are counted the number of times they occur.
Also, "00110011" is not a valid substring because all the 0's (and 1's) are not grouped together.
Example 2:
Input: s = "10101"
Output: 4
Explanation: There are 4 substrings: "10", "01", "10", "01" that have equal number of consecutive 1's and 0's.
Constraints
1 <= s.length <= 105
s[i]
is either'0'
or'1'
.
내 솔루션
- 뭔지 모르겠지만.. 손코딩하면서 알아낸 규칙으로 풀었다.
- 다 풀고나서 for문을 1번으로 줄이고 싶었으나 시간이 없어 포기
- prev를 문자를 비교 하지말고 prevCount로 받아서 현재 count와 이전 카운트를 비교하여 작은 수를 바로 저장하여 리턴하면 될 뜻.
var countBinarySubstrings = function(s) {
const map = [];
let res = 0;
let prev = null;
let tempCount = 0;
for(let i = 0 ; i < s.length ; i++){
if(prev === s[i]) {
tempCount++;
} else {
prev = s[i];
if(i !== 0) map.push(tempCount)
tempCount = 1;
}
}
map.push(tempCount)
for(let i = 0; i < map.length - 1; i++) {
res += Math.min(Number(map[i]), Number(map[i + 1]))
}
return res;
};
최고의 솔루션
- 뭐하는 녀석이지. 대단하다..
const countBinarySubstrings = (s) => s.replace(/01/g, '0,1').replace(/10/g, '1,0').split(',')
.reduce((res, a, i, arr) => i ? res + Math.min(a.length, arr[--i].length) : 0, 0);
// input 00110011
// ['00', '11', '00', '11']
// i가 0이 아닐 때부터, '00' , '11' 비교하여 작은 length를 res에 더함.
// res를 리턴함.
감상평
- 분명
easy
난이도 였는데, 풀고나선 더 어렵게 느껴진다. replace
로 array로 나눌줄은 상상도 못했다.
'coding test > leetCode' 카테고리의 다른 글
[leetCode/JS] 9. Palindrome Number (0) | 2022.11.23 |
---|---|
[leetCode/JS] 587. Erect the Fence (0) | 2022.11.23 |
[leetCode/JS] 1360. Number of Days Between Two Dates (0) | 2022.11.23 |
[leetCode/JS] 263. Ugly Number (0) | 2022.11.23 |
[leetCode/JS] 223. Rectangle Area (0) | 2022.11.23 |
Comments