© 2025 anveloper.dev
GitHub·LinkedIn·Contact

목차

  • 문제
  • 입력
  • 출력
  • 예제
  • 풀이
  • 코드
  • 복잡도
풀이 목록으로 돌아가기

BOJ 12605 - 단어순서 뒤집기

2024-11-29
BOJ
브론즈 II
cpp
원본 문제 보기
구현
문자열
스택

문제

BOJ 12605 - 단어순서 뒤집기

문장이 주어지면 단어의 순서를 뒤집어 출력하라.

입력

테스트 케이스 수 N, 각 케이스마다 문장이 한 줄씩 주어진다.

출력

각 케이스마다 "Case #i:" 형식과 함께 단어 순서를 뒤집은 문장을 출력한다.

예제

입력출력
1 this is a testCase #1: test a is this

풀이

스택을 이용하여 단어 순서를 뒤집는다.

  1. 문장을 공백 기준으로 분리하면서 각 단어와 공백을 스택에 push한다
  2. 스택에서 pop하면 자연스럽게 역순이 되므로 이를 이어 붙인다
  3. "Case #i:" 형식으로 출력한다

핵심 아이디어: 스택의 LIFO 특성을 이용하면 단어 순서가 자연스럽게 뒤집힌다.

코드

#include <iostream>
#include <stack>
#include <string>
 
using namespace std;
int main()
{
  ios_base::sync_with_stdio(false);
  cin.tie(0);
 
  int N;
  cin >> N;
  cin.ignore();
  for (int i = 1; i <= N; i++)
  {
    string s, temp, ans;
    stack<string> st;
    getline(cin, s);
 
    for (int k = 0; k < s.length(); k++)
    {
      if (s[k] == ' ')
      {
        st.push(temp);
        st.push(" ");
        temp.clear();
      }
      else
        temp += s[k];
    }
    st.push(temp);
    while (!st.empty())
    {
      ans += st.top();
      st.pop();
    }
    cout << "Case #" << i << ": " << ans << "\n";
  }
}

복잡도

  • 시간: O(N * L) (N: 테스트 케이스, L: 문장 길이)
  • 공간: O(L)