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
- 리액트쿼리
- 자바스크립트 알고리즘
- 자바스크립트 연결리스트
- Next
- react
- lodash
- 자바스크립트
- JavaScript
- Next.js13
- 타입스크립트
- leetcode문제풀이
- HTML
- til
- 자바스크립트 알고리즘 문제
- 알고리즘문제풀이
- 프론트엔드
- 자바스크립트 문제
- 자바스크립트코딩테스트
- 자바스크립트 문제 풀이
- next13
- 리액트
- 자바스크립트 문제풀이
- CSS
- leetcode
- NPM
- JS
- 프로그래머스
- stack문제
- 제로베이스
- Baekjoon
Archives
- Today
- Total
코드노트
자바스크립트 stack 알고리즘 문제 풀이 / 알파벳 순서대로 꺼내기 본문
더보기
문제 설명
a, b, c, d 순으로 저장된다고 했을 때, b, a, c, d 순으로 꺼내기 위해서는
push, push, pop, pop, push, pop, push, pop 순서대로 꺼내면 된다.
꺼내야하는 알파벳 순서가 정해질때 push/pop으로 꺼내져야 하는 동작을 계산하는 프로그램을 작성해야한다.
push = 0;
pop = 0;
배열로 반환한다.
* 주어진 순서로 못 꺼낼 경우, 빈 배열로 반환한다.
#1 입력값 = bacd
#1 출력값 = [0, 0, 1, 1, 0, 1, 0, 1]
#2 입력값 = dabc
#2 출력값 = []
#3 입력값 = edcfgbijha
#3 출력값 = [ 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1, 1, 1 ]
1. a, b, c, d 순서로 들어갈 문자열을 만든다.
2. stack에 알파벳이 없거나, stack에 있는 알파벳이 입력값 보다 작을 경우에 push를 한다.
3. push한 stack의 길이 유무 그리고 알파벳 입력값보다 클 경우에는 빈배열로 반환한다.
4. 그 외에 경우에는 pop()으로 stack에서 빼준다.
문제 풀이
function answer(str) {
let result = [];
let stack = [];
let str_res = str.split("").sort().join("");
let index = 0;
// while문으로 stack 유무 || stack끝값 < str
for (let i = 0; i < str.length; i++) {
while (stack.length === 0 || stack[stack.length - 1] < str[i]) {
stack.push(str_res[index++]);
result.push(0);
}
// if stack유무 || stack끝값 > str
if (stack.length === 0 || stack[stack.length - 1] > str[i]) {
return [];
} else {
stack.pop();
result.push(1);
}
}
return result;
}
- str_res 변수를 만드는 것 처럼 주어진 input값을 활용하면 필요없는 배열의 요소들은 제외하고 필요한 요소들로만 새로운 배열을 만들 수 있었다. 변수를 만드는것도 잘 생각을 해야할거 같다.
- for문 하나만으로도 index를 이용해서 쉽게 비교가 가능했다.
'Code note > 자바스크립트 알고리즘 문제풀이' 카테고리의 다른 글
LeetCode 58. Length of Last Word 문제풀이 자바스크립트 (0) | 2022.09.21 |
---|---|
leetcode 35. Search Insert Position 문제 풀이 자바스크립트 (0) | 2022.09.21 |
leetcode 3. Longest Substring Without Repeating Characters 문제 풀이 (0) | 2022.09.18 |
LeetCode 26. Remove Duplicates from Sorted Array 배열 문제 풀이 (0) | 2022.09.18 |
자바스크립트 stack 괄호 짝 찾기 문제 풀이 (2) | 2022.09.17 |