컴공 일기265
게시글 주소: https://old.orbi.kr/00071396715
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를 선물하세요.
-
나도육각덕해봣서 6
외모F라우럿서…
-
육각덕 ㅇㅈ 1
인생 제대로 망했네
-
장성문T 0
노베 개념문 강좌 어떤가요? 김준T는 볼륨이 너무 커요. 화1
-
골라주셈뇨 04년생이고 작년에 카투사는(올해입대) 토익 5점 미달로 못 넣음
-
제발
-
학생이라 울었어 ㅠㅠ
-
교사 쥐꼬리만한 월급 쳐받으면서 애는 어떻게 감당하려고 저리 당당하게 ㅂㅅ짓 쳐하지...
-
수탐도 잘나와준다 (1등급) > 한의대 수탐이 그럭저럭이다 (2등급) > 연세대...
-
이젠 진짜 더 안할거라고...
-
엄마가 자기 차로 픽업 안해주고 택시타고 오라해서 나랑 차별한것같아서 서운하다는데...
-
두과자
-
옯만추는 어케 하는거임
-
맨날 만나자고 올리잖아
-
내 인생 시나리오 11
여친 모집글로 100억잇는 여친 사귐 100억을 비트코인에 넣음 200억을 만듬...
-
https://youtu.be/uAxXG-BdEmA?si=ACbVJszAas5R-5x...
-
다른 두명이랑 약속잡아서 그 둘을 만나게 하는건 재밌을 것 같음
-
예비고2고 수1 노배상태에서 시발점이랑 워크북 두개 끝내고 쎈 푸는데 딴 파트는...
-
내가 미적을 다시는 안 하기로 결심한 결정적 이유 22
방금 밑에 글 보고 몫의 미분법을 떠올려보려고 했으나 기억이 안ㅋ남ㅋ ㅋㅋ ㅋㅋㅋㅋㅋㅋㅋㅋㅋ
-
조졌음 6
두각인데 앞자리에서 이상한냄새 개많이남…
-
다 밥약이였음 그래서 첫인상 물어보니까 하는 말이 “오르비 할 것 같이 생겼어요”...
-
이름이 왜 몫의 미분법이죠..?
-
선을 넘자 8
원래 주인공은 선을 넘는 거야 균형은 나머지 사람들이 잡아주겠지 우린 우리 삶의...
-
난 준비됏음
-
나도 좀 나대면서 나름대로 자의식갖고 살겠다는건데 문제있음? 꼬우면 너네도 이렇게 하던가
-
별건없고 제 세계정복의 동료가 되어주시면 됩니다
-
원하는 스펙 돈 100억잇어야댐 쿨뷰티미녀여야댐 내가집밖에안나가도뭐라고안해야댐 내...
-
이 문제 정답률이 이거 밖에 안된다고? 싶은게 많음 근데 공통 보면 공부 시간을 다...
-
어렵다어려워
-
발표를왤케안함 3
-
평소에 하던 볼륨인데 토할거같애
-
옯만추는 34
가끔은 할만 한 것 같아요 지역이 같거나 학교가 같으면 시간 내서 밥약할만 해요...
-
정보의 본질에 관하여 20.11 베이즈 주의 “연속적 이항대립과 불연속적 이항대립”...
-
서럽다 서러워...
-
11-15라인 조금만 더 어렵게해주지 특히 11번 12번 13번은 너무 했음 14번...
-
초딩때 인기 많았는데 이거
-
진짜 누구 듣지? 일단 현우진은 너무 무겁다는 느낌이 들긴했음 근데하도...
-
난 이제 장발이야
-
발표를 도대체가 왜 안하는거야 ㅅㅂ 엑셀 클릭한번이면 되는걸 사람 피말리게
-
개나줘라 병신아 걍 우선 실모배틀 이길 실력부터 만들고 예의를 쳐따져야지 난...
-
아마존에서 시켜서 까먹고 있었는데 이런게 행복이구나 너무 멀리서만 보고 있었나뵈용
-
전북치 0
8명 뽑고 예비번호 19번인데 합격 가능?? 진학사 보니까 꽤 돌거 같긴 하던데
-
인생리롤 ㄱㄱㄱㄱㄱ
-
미사카 미코토 9
-
1. 도형문제 난이도 하락 (230913급은 안나올듯) 2. 수2킬러삭제...
-
심심하니까 질문받아봄 12
아무거나 물어보세요 학습부터 오늘 밤 반찬 추천까지
-
그런걸지도
-
안녕하세요, 수능 국어를 가르치고 있는 쑥과마늘입니다. 지금이 아니면 써볼 일이...
홍컴 다니시는데 냥뱃은 뭔가요 ㄷㄷ
에리카 뱃입니다… 뭐 기념비로 가지고 있는 겁니다.
그렇군요.. 전부터 글 봐왔었는데 정말 열심히 공부하시네요
뭐… 부족하니까요. 재미는 있는데, 할 건 많아보이고, 돈은 벌어야 겠는데 게슴츠레 움직이긴 싫고…
이센스를 좋아하시나요?
바퀴가 되든가, 바퀴에 깔리든가.
난 다른 차선에 세우고 깜빡일 켜놔.
라는 라인이 하나 있는데 요새는 그 라인대로 사는 중입니다.
깜빡이 켜놓고 재밌는 거 건들이고 있어요 :)
멋있으십니다! 파이팅이에요:)
팔로우는 따로 받지 않아용 ㅠ_ㅠ
ㅠㅠ
c언어 주로 공부하시는 건가요
C, C++을 주로 보고 있습니다.
두 언어가 사실 몹시 매우 다른 속성의 언어인데 이 친구들 공통점이
컴퓨터구조 / 네트워크 / 운영체제 핵심을 자세히 살펴볼 수 있는 장점을 갖고 있어요.
말하자면, 전공 공부할 때 요긴한 언어들입니다.
스택문제 너무 어려버
스택… 어렵죠 ㅠㅠㅠ
와 꾸준하시다 멋져요
오랜만에 뵙습니다. 감사합니다 :)