문장이 주어졌을 때, 단어를 모두 뒤집어서 출력하는 프로그램을 작성하시오. 단, 단어의 순서는 바꿀 수 없다. 단어는 영어 알파벳으로만 이루어져 있다.
첫째 줄에 테스트 케이스의 개수 T가 주어진다. 각 테스트 케이스는 한 줄로 이루어져 있으며, 문장이 하나 주어진다. 단어의 길이는 최대 20, 문장의 길이는 최대 1000이다. 단어와 단어 사이에는 공백이 하나 있다.
처음 이 문제를 풀 때 물자열을 팔고 공백 마다 계산을 해주었다. 또한, 공백이 첫번째 이거나 마지막일 때는 그 상황에 맞는 식을 따로 만들어 주었다. 또한, 단어가 하나 밖에 없을 때도 예외 처리를 해주어야 했다.
하지만, 스택을 사용하면 훨씬 더 간단하게 답을 구현 할 수 있었다. 스택에 공백이 나올기 전까지 문자를 스택에 집어 넣은 다음 공백이 나올 때마다 스택을 비워주는 방법이다. 이 방법은 황인태님의 블로그에서 참고 하였다.
⭐앞으로 무언가를 순서를 거꾸로 뒤집어서 출력해야 될 때는 스택을 사용하는 방법이 좋은 방법인걸 기억해두면 좋을 것 같다.
#include <iostream>
using namespace std;
int n, empty_space[501];
int main(void){
cin >> n;
cin.ignore();
for(int i = 0; i < n; i++){
string str = "";
getline(cin, str);
int counter = 0;
for(int j = 0; j < str.size(); j++){
if(str[j] == ' '){
empty_space[counter]=j;
counter++;
}
}
//단어가 하나 밖에 없을 때
if(counter == 0){
for(int start = 0; start < str.size()/2; start++){
char temp;
temp = str[start];
str[start] = str[str.size()-1-start];
str[str.size()-1-start] = temp;
}
cout << str << endl;
}
//단어가 여러개 있을 때
else{
for(int k = 0; k < counter+1; k++){
//첫번째 공백
if(k == 0){
for(int start = 0; start < empty_space[k]/2; start++){
char temp;
temp = str[start];
str[start] = str[empty_space[k]-start-1];
str[empty_space[k]-start-1] = temp;
}
}
//마지막 공백
else if(k == counter){
for(int start = empty_space[k-1]+1; start < (empty_space[k-1]+str.size())/2+1; start++){
char temp;
temp = str[start];
str[start] = str[empty_space[k-1]+str.size()-start];
str[empty_space[k-1]+str.size()-start] = temp;
}
}
//중간 공백들
else{
for(int start = empty_space[k-1]+1; start < (empty_space[k]+(empty_space[k-1]+1))/2; start++){
char temp;
temp = str[start];
str[start] = str[empty_space[k]+empty_space[k-1]-start];
str[empty_space[k]+empty_space[k-1]-start] = temp;
}
}
}
cout << str <<endl;
}
}
}
출처: https://intaehwang.tistory.com/29
#include <iostream>
#include <stack>
#include <string>
using namespace std;
int main() {
int n;
cin >> n;
cin.ignore();
whie(n--){
string original = "";
getline(cin, original);
//마지막 단어도 뒤집어주기 위해 마지막 줄에 공백 추가
original += ' ';
stack<char> str;
for (int i = 0; i < original.size(); i++) {
//공백 보이면 단어 순서 거꾸로 출력
if (original[i] == ' ') {
while (!str.empty()) {
cout << str.top();
str.pop();
}
cout << original[i];
}
//공백 아니면 스택에 집어 넣기
else str.push(original[i]);
}
}
}