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
- 42587
- typescript
- configfile
- 완전탐색
- 좌표이동
- DP
- 파이썬
- javascript
- data platform
- python
- queue
- modbus
- algorhtim
- 개발브로그
- dfs
- Stack
- Algorithm
- summerwintercoding
- frontend
- 알고리즘
- PCCP
- javascirpt
- set활용
- 코딩테스트
- Two Pointer
- React
- 프로그래머스
- pymodbus
- 1844
- InfluxDB
Archives
- Today
- Total
DM Log
[2017 팁스타운] 짝지어 제거하기 - Python / JavaScript 본문
문제 링크 - https://school.programmers.co.kr/learn/courses/30/lessons/12973
프로그래머스
SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
[문제 간단 요약]
1. 문자의 앞에서 부터 같은 문자가 2개 연속일때 그 문자를 제거 하는 문제
[문제 해결 방안]
1. stack을 사용하여 문제 해결
2. stack에 문자열을 하나씩 넣어 가며 stack의 맨 마지막(직전) 값이랑 비교해 가면서 문제 해결
[문제 해결 코드 - python]
def solution(s):
stack = []
for i in range(len(s)):
if len(stack) == 0:
stack.append(s[i])
else:
if stack[-1] == s[i]:
stack.pop()
else:
stack.append(s[i])
return 0 if stack else 1
[문제 해결 코드 - javascript]
function solution(s) {
let stack = []
for (let i=0; i<s.length; i++) {
if (stack.length === 0) {
stack.push(s[i])
} else {
if (stack[stack.length-1] === s[i]) {
stack.pop()
} else {
stack.push(s[i])
}
}
}
if (stack.length === 0) {
return 1
} else {
return 0
}
}
'알고리즘 > 프로그래머스' 카테고리의 다른 글
[탐욕법(Greedy)] 구명보트 - Python / JavaScript (1) | 2025.02.22 |
---|---|
[완전탐색] 카펫 - Python / JavaScript (0) | 2025.02.18 |
[연습문제] 피보나치 수 - Python / JavaScript (0) | 2025.02.16 |
[연습문제] 숫자의 표 - Python / JavaScript (2) | 2025.02.09 |
[월간 코드 첼린지 시즌1] 이진 변환 반복하기 - Python / JavaScript (2) | 2025.02.08 |