leetcode 알고리즘 문제 604 (간단 154) 반복 압축 문자열
제목 소개
, ,
: next hasNext。
:
, 。
next() - , , 。
hasNext() - 。
:
StringIterator ,
。
예시
StringIterator iterator = new StringIterator(“L1e2t1C1o1d1e1”); iterator.next(); // "L" iterator. next (); /"e" iterator. next (); /"e" iterator. next (); /'t' iterator. next (); /"C" iterator. next (); /'o' iterator. next (); /"d" iterator. hasNext (); /true iterator. next (); /"e" iterator. hasNext (); /false iterator. next (); /되돌아오다
해법
/**
* @param {string} compressedString
*/
var StringIterator = function(compressedString) {
let i = count = 0, number = '', list = [];
while(i < compressedString.length) {
if(isNumber(compressedString.charCodeAt(i))) {
number += compressedString[i];
} else {
if(number) {
list.push(number);
number = '';
}
list.push(compressedString[i]);
}
i++;
}
if(number) {
list.push(number);
}
this.list = list;
};
const isNumber = code => {
return code >= 47 && code <= 57;
}
const stringNumberReduc = number => {
let i = number.length - 1, flag = true, str = '';
while(i >= 0) {
if(!flag) {
str = number[i] + str;
} else {
if(i === 0 && flag && number[i] === '1') {
return str || '0';
}
if(number[i] === '0') {
str = '9' + str;
} else {
str = parseInt(number[i]) - 1 + str;
flag = false;
}
}
i--;
}
return str;
}
/**
* @return {character}
*/
StringIterator.prototype.next = function() {
let list = this.list;
if(list.length === 0) {
return ' ';
}
let s = list[0];
list[1] = stringNumberReduc(list[1]);
if(list[1] === '0') {
list.shift();
list.shift();
}
return s;
};
/**
* @return {boolean}
*/
StringIterator.prototype.hasNext = function() {
return this.list.length > 0;
};
/**
* Your StringIterator object will be instantiated and called as such:
* var obj = new StringIterator(compressedString)
* var param_1 = obj.next()
* var param_2 = obj.hasNext()
*/
실행 시: 100 ms, 모든 자 바스 크 립 트 제출 중 100.00% 사용 자 를 격파
메모리 소모: 38.9MB, 모든 JavaScript 제출 중 100.00% 사용 자 를 격파
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Rails Turbolinks를 페이지 단위로 비활성화하는 방법원래 Turobolinks란? Turbolinks는 링크를 생성하는 요소인 a 요소의 클릭을 후크로 하고, 이동한 페이지를 Ajax에서 가져옵니다. 그 후, 취득 페이지의 데이터가 천이 전의 페이지와 동일한 것이 있...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.