컴공 일기265
https://school.programmers.co.kr/learn/courses/30/lessons/76502
프로그래머스 문제입니다.
스택을 이용해, 입력된 괄호끼리 짝을 다 맞출 수 있는지를 판단하는 겁니다.
‘짝’이라는 것을 어떻게 프로그래밍 언어로 표현할 것이냐를 묻고 있는데, 가장 일반적인 접근은 조건문이죠.
if(stack.top == ‘(‘ && input == ‘)’) // true
if(stack.top == ‘{ && input == ‘}’) // true
if(stack.top == ‘[‘ && input == ‘]’) // true
이런 식으로요.
실제로 제가 기술했던 코드에서도 조건문에 기반하여 짝을 확인하고 있습니다.
하지만, 조금 더 멋있게 푸는 방법이 있으니 그것은.. C++ STL(standard library)에서 지원하는
unordered_map 자료구조를 이용하는 겁니다.
맵은 일종의 순서쌍이라고 생각하면 되는데 굳이 조건절 반복해서 쓰지말고, 아예 통째로
unordered_map 자료구조에 (’{‘, ’}‘) (’[‘, ’]‘) (’(‘, ’)‘)를 미리 저장해 두고 확인만 해보면 된다는 논리죠.
제가 아래 기술한 풀이보다 unordered_map 자료구조를 이용한 풀이가
readability가 더 좋을 겁니다.
다만 뭐… 이 풀이도 나쁜 건 아니죠.
#include <iostream>
#include <string>
#include <stack>
using namespace std;
void answer(string& s, int& ans)
{
stack<char> st;
int size = s.size();
for(int i=0; i<size; i++)
{
//열린 괄호만을 스택에 push
if(s[i] == '(' || s[i] == '[' || s[i] == '{')
{
st.push(s[i]);
}
else
{
//스택이 비어있는 상태라면 짝을 맞출 수 없으므로 종료
if(st.empty()) return;
//괄호끼리 짝을 지을 수 있는지 확인
if(s[i] == ']' && st.top() == '[') st.pop();
else if(s[i] == ')' && st.top() == '(') st.pop();
else if(s[i] == '}' && st.top() == '{') st.pop();
}
}
//문자열 끝까지 확인한 후 스택이 비어있다면 그 문자열은 괄호끼리 짝을 전부 맞출 수 있음
if(st.empty()) ans++;
}
void left_rotation(string& s)
{
int size = s.size();
char first = s[0];
for(int i=0; i< size-1; i++)
{
s[i] = s[i+1];
}
s[size-1] = first;
}
int solution(string s)
{
int size = s.size();
int ans = 0;
for(int i=0; i<size; i++)
{
answer(s, ans);
left_rotation(s);
}
return ans;
}
0 XDK (+0)
유익한 글을 읽었다면 작성자에게 XDK를 선물하세요.
-
작수 4떴음요 마더텅ㅇ나 자이스토리로 혼자 오래 고민하면서 기출분석? 이런것도...
-
작수 65점이면 노베인가요
-
쓰니는 꼭 물리현강가서 여자 옆에 앉아봐
-
제발…
-
맞팔하실분 4
근데 잡담태그 안 다는 사람은 안 받음
-
1. 공리를 부정하면 무모순 2. 결론을 부정하면 무모순 즉, 공리가 거짓이어도...
-
경한 vs 원광치에서 경한을 고르는 대다수의 사람들이 서울에 있어서, 한의대 중 젤...
-
알바구하기 포기 7
봉사랑 헌혈이나 해둬야지 에휴…
-
배신자는 귀엽다 4
이것은 사실이다.
-
현역 생2 선택 7
25수능 국수 1컷 나오고 물1 2등급, 생1 1컷 나오고 설공 목표하고 있어요.....
-
자기보다 나이 어린 여자애가 푸는 문제도 못푸는거야? 허접♡ 초월함수의 극한도...
-
기출 끝냈다고 할 수 있는건가요 아님 마더텅이나 자이스토리 같은거 더 풀어야하나요
-
학원 생활까지 다 끝내고 보니 학종러들도 논술러들도 고충이 심하다고 느껴서 아 물론...
-
샹밑미 ㅋㅋㅋ
-
컷당했다 ㅠㅠ
-
도코마데모 8
츠즈쿠요-나 아오노 키세츠와~
-
빠꾸없노
-
의학대학외국어대학와플대학
-
저는 아직 합격 발표 기다리고 있는데 수시로 합격하고 벌써 에타 들어가서 시간표...
-
안녕하세요 제발 한번만 도와주세요 재수생이고 현역 때 수학 15 20 21 22...
-
혼자 생각할 줄도 알고 진득히 공부하다 정말 몰랐을 때 질문하는 게 좋다 생각함...
-
앞부분 정부 형태 기본권 이란거 안 하고 선거 먼저 해도 돼요?!?
-
17살 수학 노베이스 입니다. 중학교 2학년 2학기 중간고사 이후부터 수학을...
-
투표 점..
-
고대생이랑 연애하기 cc는 ㄴㄴ
-
재수생이고 언매,영어 고정1 미적 92-96 왔다갔다 생1은 내신전교1등도 하고...
-
평가원꺼는 선지 소거법으로 풀 수 있는데 월간지는 내용 해석햐도 문제가 안풀림 ㅠㅠ
-
투표 부탁드려요...
-
확률과 통계 개혁안 10
일단 통통이 들이 가장 무시받는 이유는 이름이 너무 약해서임 그냥 ㅈ간지나게 이름...
-
인서울 하위권 4년제 다니다 휴학하고 군복무중입니다 군수 다짐하고 수학부터...
-
교재를 1월중으로 판매하겠죠???
-
일본어 곤부해서 10
말년엔 일번 여행가야지 아직도 413일 남았다
-
똑같은 3일인데 0
날이 살짝 풀리니까 작년 이맘때에 한창 뉴런 들을 때 생각이 나네요 연초의 3일은...
-
1컷을 받고 싶으면 본인이 생각하는 만점 공부량을 목표로 삼는 게 좋음 그리고 가끔...
-
독감 진짜 みちん놈임 12
걸린지 엿새째인데도 고열이 나는 みちん질병 확진 당일날 타미플루 맞았는데도 이러네...
-
아이젠이 딱 저한테 어렵지도 않고 쉽지도 않은 적당한 착붙 수준인데 이정도면 뭔 공부해야할까요ㅠ
-
17살 국어 노베이스(7~9등급) 입니다. 윤혜정 선생님 커리큘럼을 따라갈건데 제가...
-
사랑한 나를 뭐가 그리 바쁜지 너무 보기 힘들어
-
디맥하자 디맥 4
근데 디맥 까는데 한시간넘게걸림 어제밤동안 2시간동안 깔았는데도
-
뭐이렇게 많아 3
사평우 뻘글머신인건가
-
고닥교때 친구랑 내기해서 진사람 탭+가방에 씹덕스티커 붙이고 다니기로 함,...
-
아프리카티비가 soop으로 이름 바뀌었네 이제 알았다는.. 언제부터 바뀐거지
-
배가 아프다 0
으아
-
시발점 후 1
담주에 시발점 끝나는데 다음에 뭐 풀면 되나요? 수분감 생각중이긴한대 시발점은...
-
히히 프사 바꿈 2
귀엽다
-
제가 대성패스를 끊었는데 이미지쌤이 노베한테 좋다는데 들어도 될까요 현재 수학...
-
83(3) 95(2) 2 90(2) 87(3) 언미영물생 순인데 목동 시대재종...
-
+유대종 현강
-
국어 인강 들말 2
국어도 인강 들어야하나요? 들으면 좋을 것 같긴 한데 수학이 많이 급하고 사탐으로...
-
연대기원제발 ㅠㅠㅠㅠ하느님부처님 연대붙으면 미련없이 떠나겠습니다 제발 연대...
홍컴 다니시는데 냥뱃은 뭔가요 ㄷㄷ
에리카 뱃입니다… 뭐 기념비로 가지고 있는 겁니다.
그렇군요.. 전부터 글 봐왔었는데 정말 열심히 공부하시네요
뭐… 부족하니까요. 재미는 있는데, 할 건 많아보이고, 돈은 벌어야 겠는데 게슴츠레 움직이긴 싫고…
이센스를 좋아하시나요?
바퀴가 되든가, 바퀴에 깔리든가.
난 다른 차선에 세우고 깜빡일 켜놔.
라는 라인이 하나 있는데 요새는 그 라인대로 사는 중입니다.
깜빡이 켜놓고 재밌는 거 건들이고 있어요 :)
멋있으십니다! 파이팅이에요:)
팔로우는 따로 받지 않아용 ㅠ_ㅠ
ㅠㅠ
c언어 주로 공부하시는 건가요
C, C++을 주로 보고 있습니다.
두 언어가 사실 몹시 매우 다른 속성의 언어인데 이 친구들 공통점이
컴퓨터구조 / 네트워크 / 운영체제 핵심을 자세히 살펴볼 수 있는 장점을 갖고 있어요.
말하자면, 전공 공부할 때 요긴한 언어들입니다.
스택문제 너무 어려버