컴공 일기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를 선물하세요.
-
수능칠때 귀마개 0
ㄹㅇ 필수인듯? 본인 9평까지 안끼다가 9덮인가 10덮에 ㅁㅊ 빌런 만나보고 바로...
-
?
-
기빨림.
-
아무생각 4
싫
-
여자친구 구해요 9
잘해드립니다
-
국어 과외 지문 3
독서 붙여읽기 습관 잡는 데에 좋은 기출 지문 머가 있을까요?ㅠㅠㅠㅠ 소정의 덕코 드려요 ㅠㅠ
-
내시험실은 2
미적 29를 30이랑 42?랑 갈드컵하고있더라
-
일어나자마자 밥주고 밥먹으면 더먹으라고 밥주고 밥 다먹으면 다음 밥 먹을때까지...
-
나갔네.. 8
헤휴..
-
재업) 성장곡선 5
곡선이 아니긴한데 쨋든. 32->74 캬캬암산테스트 그거임
-
드레이븐 스택 20분동안 900스택 쌓고 터트렸는데 비트코인이 이런 느낌이구나 9
뇌가 절여지는 느낌을 받음..
-
히카루가 죽은 여름 10
오랜만에 읽을만한거 찾았네요 게@이물이라고 하길래 쫄앗는데 실눈뜨고 보면 그냥 친한...
-
한 달 째 안 씻었는데 13
지금 시험보면 물1 만점 가능?
-
에어컨이 아예 고장나서 제습도 안되고 온도 조절도 안됨ㅋㅋㅋ 이산화 탄소 존나...
-
ㅠㅠ
-
난 5명정도 남고 나머지 다 포기각서
-
저리가세요
-
생윤하고 한지 찍먹해보고싶은데 뭘로 어떻게 해볼까여 0
ㅈㄱㄴ 탐구 찍먹 해본적이 없어서… 사탐런하는데 뭐가 나랑 맞는지 확인하고 싶어서 찍먹해보고 싶음!
-
물탔는데 증거금 터지면 진짜 자살함...
-
왜냐면 나도 따뜻한거 마시는 비중이 전보다 늘었음...
-
???
-
오래된 생각이다.
-
기운나는구만
-
반수 국어 탐구 시간 말곤 파본검사 안해봄
-
웃으면서 떠드는 거 원래 그런 거임?? 이거 컴플레인 걸어도 되는 건지 아닌지...
-
파본검사를 안시켜주길래 조마조마하고 있었는데 왼쪽 앞 친구(오르비, 디시할거같이...
-
살쪗어요 2
77kg됨
-
일을 안 하고 먹고 살고 싶구나
-
그 사람 성별을 짐작하게 됨. 여캐 프로필은 여르비로 무의식적으로 인식함. 그래서...
-
있었음? 소수말고 다수
-
수능 감독관 <<<<< 이새끼들 왜 잘못해도 걍 넘어감? 7
수험생 최소 몇십명의 인생이 이새끼들 손에 달린거 아님? 신상 까고 면직을 하던...
-
저능아가 설대설로검사루트타는거 보여줄게
-
그런데 하나 안하나 60점대에서 70점대길래 나중에는 그냥 틀린건 틀렸다고 했어
-
스파게티 튀기기 5
-
신년 다이어트법 12
식비로 쓸 돈을 없애서 강제로 굶는다
-
상상이상이군ㄴㅎ
-
오늘 저녁 메뉴 추천 좀
-
특히 모고때 아 이거 내가 이런 발상을 못했으면 틀렸겠지…? 하면서 리버스 호머...
-
지하캠퍼스 공사땜에 축제 당분간 없다는데 오피셜인가여
-
내 멘탈이 더 중요함
-
고려대학교 신소재공학부에서 25학번 새내기를 찾습니다! 0
안녕, 안녕, 안녕하십니까~~ 민족 고대?강철~공대?재료~금속⭐️혁! 신소재!⚛️...
-
아 나도 이론상으로는 수능만점 가능하다고 ㅋㅋ
-
수능잘보면그만이야~ 6월 7월 9월 합쳐서 3점 5개 틀렸는데 수능은 3점 다 맞음 ㅎㅎ
-
스블 확통은 3월에나 종강이라는데 첫해 강민철쌤처럼 사단날라나
홍컴 다니시는데 냥뱃은 뭔가요 ㄷㄷ
에리카 뱃입니다… 뭐 기념비로 가지고 있는 겁니다.
그렇군요.. 전부터 글 봐왔었는데 정말 열심히 공부하시네요
뭐… 부족하니까요. 재미는 있는데, 할 건 많아보이고, 돈은 벌어야 겠는데 게슴츠레 움직이긴 싫고…
이센스를 좋아하시나요?
바퀴가 되든가, 바퀴에 깔리든가.
난 다른 차선에 세우고 깜빡일 켜놔.
라는 라인이 하나 있는데 요새는 그 라인대로 사는 중입니다.
깜빡이 켜놓고 재밌는 거 건들이고 있어요 :)
멋있으십니다! 파이팅이에요:)
팔로우는 따로 받지 않아용 ㅠ_ㅠ
ㅠㅠ
c언어 주로 공부하시는 건가요
C, C++을 주로 보고 있습니다.
두 언어가 사실 몹시 매우 다른 속성의 언어인데 이 친구들 공통점이
컴퓨터구조 / 네트워크 / 운영체제 핵심을 자세히 살펴볼 수 있는 장점을 갖고 있어요.
말하자면, 전공 공부할 때 요긴한 언어들입니다.
스택문제 너무 어려버
스택… 어렵죠 ㅠㅠㅠ
와 꾸준하시다 멋져요
오랜만에 뵙습니다. 감사합니다 :)