컴공 일기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를 선물하세요.
-
쉽지가않네
-
지문에 (대충 어떤 주장이나 가설) 그러나 이는 다양한 비판에 직면한다. 대표적으로...
-
️ 연세대학교 중앙새내기맞이단에서 25학번 아기독수리들을 환영합니다 ⭐️ 0
⭐️ 연세대학교 25학번 아기독수리들 주목 ⭐️ 안녕하세요! 연세대학교...
-
에타에서도 난리인거죠 삼성이랑 연줄 있는 학과들이면 몰라 그런거 없이 물으면 어쩌자는
-
우웅
-
실제로 이런 일도 가능 하지 않으 ㄹ ㄲ ㅏ?? 진짜 ㄹ ㅜ
-
헤헷... 6
가끔씩 내가 너무 공부못하는 것 같다고 느껴서ㅜ우울해졌을때 오르비들어오면 기분이조아짐ㅋㅋ
-
하프모? 제외하고 한권에 2x16=32지문 맞나요? +매일 문/독 1지문씩 고정인가유
-
러셀 대치 원서랑 러셀 기숙학원 원서랑 중복으로 지원 못 하나요? § 중복접수 확인...
-
[칼럼] 2025 수능 응시자가 2월에 해야할 일 14
안녕하세요! 설 연휴 잘 보내셨나요? 오늘은 올해의 첫 장이 벌써 끝나고 다음...
-
문학 사라져야댐 15
리트화해야햄
-
?
-
오고곡오고고고곡 0
크리스피 오곡롤~
-
중경외시 라인 문과 정시 일반 예비 1번인데 원래는 당연히 붙겠지 싶었습니다 그런데...
-
예쁘다...
-
1지망 2지망 이렇게 점공에 작성해놓은 대로 보통 최종등록하나요?
-
과외쌤 목소리로 5
실수해서 아아앙이러는데 너무 좋은데 고백하면 안되나요?
-
미3누 멋있네 3
와
-
경계선 지능은 아닌거지?
-
이건 연의생만 쓸수있는데 주제넘게한번써봄
-
기분진짜이상함 내친구가 엄마아빠가된다라
-
장성문T 0
개념문 노베한테 부족한가요? 김준T는 볼륨이 너무 커서요… (화학 학원 하나 다니고 있습니다)
-
대학커뮤니티 노크에서 선발한 한양대 선배가 오르비에 있는 예비 한양대학생, 한양대...
-
누구는 sky 미만잡이라 하고 누구는 메디컬 미만잡이라 하는데 현실에선 ㅁㅌㅊ인가요
-
전에 만나던사람이랑 좀 롱디였는데 너무 바빠서 거의 매번 내가 보러갔었음 그래서...
-
ㅇㅇ
-
걍 설탭이랑. 똑같이 시급2받고 해버려? ㅋㅋ
-
눈이 안온다 단점:눈이 안 온다
-
농어촌 의대 2
농어촌이고 정시로 연세대 의대 지망하는데 아무리 농어촌이어도 과탐+사탐 조합으로는 불가능하겠죠?
-
대학커뮤니티 노크에서 선발한 서강대 선배가 오르비에 있는 예비 서강대생, 서대...
-
외고애들 수학때 싹 자던거 빼고는 좋았음 감독관님들도 이것저것 안따지고 거의 다...
-
국민대 합격생을 위한 노크선배 꿀팁 [국민대25][기숙사, 자취방, 고시원] 0
대학커뮤니티 노크에서 선발한 국민대 선배가 오르비에 있는 예비 국민대학생, 국민대...
-
격자점 재밌음 4
격자점은 그래도 지수로그 성질 이용해서 내도 거부감은 없는데 삼도극,무등비는 솔직히...
-
딱 돈만 놓고 보면 꼭 그렇지도 않나... 예체능계 최정상들은 제외하고요 그쪽은 차피 못함
-
오르비 3
육르비
-
수학황 분들 질문할게요 14
이거 좀 풀어주실수있나요
-
배송을 바란다. 2
급해요
-
과외끝남요 4
헤헤
-
강의 듣다가 교재에 없는 거 칠판에 띄워지면 2511 2510 2509 2507...
-
수용가능한 선에서 한번정돈 더 나오지 않을가
-
근데 이분은 그냥 천재인듯... 영상미 미침 영상쪽 전공자는 아니래요
-
동국대 조발 0
ㅈㅈ하게 오늘 뜨냐 오늘 아니면 의미가업음
-
덕코 주세요 6
감사합니다
-
인스타 맞팔이라도 해놓을걸… 뉴비라서 듀오 은근 재밌었는데 아쉽다
-
수학 기출 0
기본개념을 끝내고 냅다 자이스토리 사서 풀었었거든요 1등급(별3개) 문제들은...
-
아 이거 풀기시룬뎅 ㅇㅅㅇ
-
상관없나
-
럭키편돌이나 개부랄따개가 됐을텐데.... 다시보면 메쟈의? 럭키빗치자나
-
고3때 생각나네
-
시립대 일주일만 3
조발해주면 안되겠니? 간절해..
홍컴 다니시는데 냥뱃은 뭔가요 ㄷㄷ
에리카 뱃입니다… 뭐 기념비로 가지고 있는 겁니다.
그렇군요.. 전부터 글 봐왔었는데 정말 열심히 공부하시네요
뭐… 부족하니까요. 재미는 있는데, 할 건 많아보이고, 돈은 벌어야 겠는데 게슴츠레 움직이긴 싫고…
이센스를 좋아하시나요?
바퀴가 되든가, 바퀴에 깔리든가.
난 다른 차선에 세우고 깜빡일 켜놔.
라는 라인이 하나 있는데 요새는 그 라인대로 사는 중입니다.
깜빡이 켜놓고 재밌는 거 건들이고 있어요 :)
멋있으십니다! 파이팅이에요:)
팔로우는 따로 받지 않아용 ㅠ_ㅠ
ㅠㅠ
c언어 주로 공부하시는 건가요
C, C++을 주로 보고 있습니다.
두 언어가 사실 몹시 매우 다른 속성의 언어인데 이 친구들 공통점이
컴퓨터구조 / 네트워크 / 운영체제 핵심을 자세히 살펴볼 수 있는 장점을 갖고 있어요.
말하자면, 전공 공부할 때 요긴한 언어들입니다.
스택문제 너무 어려버
스택… 어렵죠 ㅠㅠㅠ
와 꾸준하시다 멋져요
오랜만에 뵙습니다. 감사합니다 :)