Stack

์Šคํƒ์€ ํ•œ์ชฝ ๋์—์„œ๋งŒ ์ž๋ฃŒ๋ฅผ ๋„ฃ๊ณ  ๋บ„ ์ˆ˜ ์žˆ๋Š” ์ž๋ฃŒ๊ตฌ์กฐ์ด๋‹ค.

  • LIFO(Last In First Out) ๋งˆ์ง€๋ง‰์œผ๋กœ ๋„ฃ์€ ๊ฒƒ์ด ๊ฐ€์žฅ ๋จผ์ € ๋‚˜์˜จ๋‹ค. ์ฆ‰, ์ž…๋ ฅ์ˆœ์„œ์™€ ์—ญ์ˆœ์˜ ์ถœ๋ ฅ์ด ํ•„์š”ํ•œ ๊ฒฝ์šฐ์— ์‚ฌ์šฉํ•˜๋Š” ๊ฒƒ์ด ์ข‹๋‹ค.

    • ์—๋””ํ„ฐ์—์„œ ๋˜๋Œ๋ฆฌ๊ธฐ(undo) ๊ธฐ๋Šฅ

    • ํ•จ์ˆ˜ ํ˜ธ์ถœ ์‹œ ๋ณต๊ท€์ฃผ์†Œ ๊ธฐ์–ต

์—ฐ์‚ฐ

์„ค๋ช…

push

์Šคํƒ์— ์ž๋ฃŒ๋ฅผ ๋„ฃ๋Š” ์—ฐ์‚ฐ

pop

์Šคํƒ์—์„œ ์ž๋ฃŒ๋ฅผ ๋นผ๋Š” ์—ฐ์‚ฐ

top / peak

์Šคํƒ์˜ ๊ฐ€์žฅ ์œ„์— ์žˆ๋Š” ์ž๋ฃŒ๋ฅผ ๋ณด๋Š” ์—ฐ์‚ฐ

empty

์Šคํƒ์ด ๋น„์–ด์žˆ๋Š”์ง€ ์•„๋‹Œ์ง€๋ฅผ ์•Œ์•„๋ณด๋Š” ์—ฐ์‚ฐ

full

์Šคํƒ์ด ํฌํ™”์ƒํƒœ์ธ์ง€ ๊ฒ€์‚ฌํ•˜๋Š” ์—ฐ์‚ฐ

size

์Šคํƒ์— ์ €์žฅ๋˜์–ด์žˆ๋Š” ์ž๋ฃŒ์˜ ๊ฐœ์ˆ˜๋ฅผ ์•Œ์•„๋ณด๋Š” ์—ฐ์‚ฐ

์Šคํƒ์˜ ๊ตฌํ˜„

๋ฐฐ์—ด

  • ์žฅ์  : 1์ฐจ์› ๋ฐฐ์—ด๋กœ ์‰ฝ๊ฒŒ ๊ตฌํ˜„ํ•  ์ˆ˜ ์žˆ๋‹ค.

  • ๋‹จ์  : ๋ฌผ๋ฆฌ์ ์œผ๋กœ ํฌ๊ธฐ๊ฐ€ ๊ณ ์ •๋œ ๋ฐฐ์—ด์„ ์‚ฌ์šฉํ•˜๋ฏ€๋กœ ์Šคํƒ์˜ ํฌ๊ธฐ ๋ณ€๊ฒฝ์ด ์–ด๋ ต๋‹ค.

#include <stdio.h>
#define MAX 20

typedef struct{
    int stack[MAX];
    int top;    //stack์ด ๋น„์–ด์žˆ์„ ๊ฒฝ์šฐ -1
}StackType;

void init(StackType *s);
int is_full(StackType *s);
int is_empty(StackType *s);
int peak(StackType *s);
void push(StackType *s, int );
int pop(StackType *s);
//์Šคํƒ ์ดˆ๊ธฐํ™”
void init(StackType *s){
    s->top = -1;
}

int is_empty(StackType *s){
    return (s->top == -1);
}

int is_full(StackType *s){
    return (s->top == MAX-1);
}

int peak(StackType *s){
    if(is_empty(s)){
        printf("์Šคํƒ์ด ๋น„์–ด์žˆ์Šต๋‹ˆ๋‹ค.");
        return -1;
    }else return s->stack[s->top];
}

void push(StackType *s, int data){
    if(is_full(s)){
        printf("์Šคํƒ์— ๊ณต๊ฐ„์ด ์—†์Šต๋‹ˆ๋‹ค.");
    }else{
        s->stack[++s->top]=data;
    }
}

int pop(StackType *s){
    if(is_empty(s)){
        printf("์Šคํƒ์ด ๋น„์–ด์žˆ์Šต๋‹ˆ๋‹ค.");
        return -1;
    }else{
        return s->stack[s->top--];
    }
}
#include <iostream>
#include <string>
using namespace std;
struct Stack {
    int data[10000];
    int size;
    Stack() {
        size = 0;
    }
    void push(int num) {
        data[size] = num;
        size += 1;
    }
    bool empty() {
        if (size == 0) {
            return true;
        } else {
            return false;
        }
    }
    int pop() {
        if (empty()) {
            return -1;
        } else {
            size -= 1;
            return data[size];
        }
    }
    int top() {
        if (empty()) {
            return -1;
        } else {
            return data[size-1];
        }
    }
};
int main() {
    int n;
    cin >> n;

    Stack s;

    while (n--) {
        string cmd;
        cin >> cmd;
        if (cmd == "push") {
            int num;
            cin >> num;
            s.push(num);
        } else if (cmd == "top") {
            cout << (s.empty() ? -1 : s.top()) << '\n';
        } else if (cmd == "size") {
            cout << s.size << '\n';
        } else if (cmd == "empty") {
            cout << s.empty() << '\n';
        } else if (cmd == "pop") {
            cout << (s.empty() ? -1 : s.top()) << '\n';
            if (!s.empty()) {
                s.pop();
            }
        }
    }
    return 0;
}
# ํŒŒ์ด์ฌ์—์„œ๋Š” ์Šคํƒ์„ ์ด์šฉํ•  ๋•Œ ๋ณ„๋„์˜ ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ๋ฅผ ์‚ฌ์šฉํ•  ํ•„์š” ์—†์Œ.
# ๊ธฐ๋ณธ ๋ฆฌ์ŠคํŠธ์—์„œ append(), pop() ๋ฉ”์„œ๋“œ๋ฅผ ์ด์šฉํ•˜๋ฉด ์Šคํƒ๊ณผ ๋™์ผํ•˜๊ฒŒ ๋™์ž‘

stack = []

stack.append(1)
stack.appned(5)
stack.pop()

์—ฐ๊ฒฐ ๋ฆฌ์ŠคํŠธ

  • ์žฅ์  : ํฌ๊ธฐ๊ฐ€ ์ œํ•œ๋˜์ง€ ์•Š๋Š”๋‹ค.

  • ๋‹จ์  : ๊ตฌํ˜„์ด ๋ณต์žกํ•˜๊ณ  ์‚ฝ์ž…์ด๋‚˜ ์‚ญ์ œ ์‹œ๊ฐ„์ด ์˜ค๋ž˜๊ฑธ๋ฆฐ๋‹ค.

#include <stdio.h>
#include <stdlib.h>

typedef struct stack{
    int data;
    struct stack * next;
}Stack;

void init(Stack *s);
int is_empty(Stack *s);
int peak(Stack *s);
void push(Stack **,Stack **, int );
void pop(Stack **,Stack **);
#include "stack_list.h"

Node * new_node(int data){
    Node * new = (Node *)malloc(sizeof(Node));
    new->next=NULL;
    new->data = data;
    return new;
}

//์Šคํƒ ์ดˆ๊ธฐํ™”
void init(Stack *s){
    s = NULL;
}

int is_empty(Stack *s){
    return (s == NULL);
}

int peak(Stack *s){
    if(is_empty(s)){
        printf("์Šคํƒ์ด ๋น„์–ด์žˆ์Šต๋‹ˆ๋‹ค.");
        return -1;
    }else return s->data;
}

void push(Stack **top, int data){
    Stack * new;
    if(is_empty(*top)){
        new=new_node(data);
    }
    else{
        new = new_node(data);
        new->next = *top;
    }
    *top=new;
}

void pop(Stack **top){

    Node * p = *top;

    if(is_empty(p)){
        printf("์Šคํƒ์ด ๋น„์–ด์žˆ์Šต๋‹ˆ๋‹ค.\n");
        return ;
    }
    *top = p->next;
    free(p);
}

๊ตฌํ˜„ํ•˜๋Š” ๊ฒƒ๋ณด๋‹ค ์งœ์—ฌ์ ธ ์žˆ๋Š” ๊ฒƒ์„ ์“ฐ๋Š”๊ฒŒ ์ข‹๋‹ค.

#include <iostream>
#include <stack>
#include <string>
using namespace std;


int main ()
{
    stack<int> mystack;
    int n;
    scanf("%d",&n);

    while(n--){
        string ss;
        cin >> ss;

        if(ss=="push"){
            int num;
            scanf("%d",&num);
            mystack.push(num);
        } else if(ss=="top"){
            cout << (mystack.empty() ? -1 : mystack.top())<<"\n";
        } else if(ss=="size"){
            cout << mystack.size()<<"\n";
        } else if(ss=="empty"){
            cout << mystack.empty()<<"\n";
        } else if(ss=="pop"){
            cout << (mystack.empty() ? -1 : mystack.top())<<"\n";
            if(!mystack.empty()){
                mystack.pop();
            }
        }
    }
}

์‹ค์Šต

๊ด„ํ˜ธ(VPS)

  • ์˜ฌ๋ฐ”๋ฅธ ๊ด„ํ˜ธ ๋ฌธ์ž์—ด์˜ ์˜ˆ์‹œ

    • ()

    • (())()

    • ((()))

  • ์˜ฌ๋ฐ”๋ฅธ ๊ด„ํ˜ธ ๋ฌธ์ž์—ด์ด ์•„๋‹Œ ์˜ˆ

    • (()(

    • (()()))

    • (()

์Šคํƒ์„ ์ด์šฉํ•ด์„œ ๊ด„ํ˜ธ ๋ฌธ์ž์—ด์ธ์ง€ ์•„๋‹Œ์ง€ ์•Œ ์ˆ˜ ์žˆ๋‹ค. 1. (๊ฐ€ ๋‚˜์˜ค๋ฉด ์Šคํƒ์— ๋„ฃ๋Š”๋‹ค. 2. )๊ฐ€ ๋‚˜์˜ค๋ฉด ์Šคํƒ์—์„œ ํ•˜๋‚˜๋ฅผ ๋นผ์„œ (์ธ์ง€ ํ™•์ธํ•œ๋‹ค.

์‹œ๊ฐ„๋ณต์žก๋„ O(N^2)

=> ์Šคํƒ์„ ์ด์šฉํ•ด์„œ O(N)์„ O(1)๋กœ ์ค„์ผ ์ˆ˜ ์žˆ๋‹ค.

[์˜ˆ์‹œ]

  • (())()

    ์Šคํƒ: (

  • (())()

    ์Šคํƒ: ((

  • (())()

    ์Šคํƒ: (

  • (())()

    ์Šคํƒ:

  • (())()

    ์Šคํƒ: (

  • (())()

    ์Šคํƒ:

๋ชจ๋“  ๊ณผ์ •์ด ๋๋‚œ ํ›„ ์Šคํƒ์ด ๋น„์–ด์žˆ์œผ๋ฏ€๋กœ ์˜ฌ๋ฐ”๋ฅธ ๊ด„ํ˜ธ ๋ฌธ์ž์—ด์ด๋‹ค. ๋งŒ์•ฝ ๋ชจ๋“  ๊ณผ์ •์ด ๋๋‚œ ํ›„ ์Šคํƒ์ด ๋น„์–ด์žˆ์ง€ ์•Š์œผ๋ฉด ์˜ฌ๋ฐ”๋ฅธ ๊ด„ํ˜ธ ๋ฌธ์ž์—ด์ด ์•„๋‹ˆ๋‹ค.

๊ทธ๋Ÿฌ๋ฏ€๋กœ ์Šคํƒ์— ๋ช‡๊ฐœ(size)๊ฐ€ ๋“ค์–ด๊ฐ€ ์žˆ๋Š”์ง€๊ฐ€ ์ค‘์š”ํ•˜๋‹ค!

#include <iostream>
#include <stack>
#include <string>
using namespace std;

string valid(string s){
    int cnt=0;
    for(int i=0;i<=s.size();i++){
        if(s[i]=='('){
            cnt += 1;
        }else if(s[i]==')'){
            cnt -= 1;
        }
        if (cnt < 0) {
            return "NO";
        }
    }
    if (cnt == 0) {
        return "YES";
    }else{
        return "NO";
    }
}
int main(){
    int t;
    cin >> t;

    while(t--){
        string ps;
        cin >> ps;

        cout<<valid(ps)<<"\n";
    }
}

๊ด„ํ˜ธ ์šฐ์„ ์ˆœ์œ„

  • ๊ทœ์น™

    1. ๋Œ€๊ด„ํ˜ธ'[]'๋Š” ์ค‘๊ด„ํ˜ธ'{}', ์†Œ๊ด„ํ˜ธ'()' ์•ˆ์— ์˜ฌ ์ˆ˜ ์—†๋‹ค.

    2. ์ค‘๊ด„ํ˜ธ๋Š” ์†Œ๊ด„ํ˜ธ ์•ˆ์— ์˜ฌ ์ˆ˜ ์—†๋‹ค.

    3. ์—ฌ๋Š” ๊ด„ํ˜ธโ€™(โ€˜,โ€™{โ€˜,โ€™[โ€˜๊ฐ€ ๋‚˜์˜ค๋ฉด ์Šคํƒ์— ๋„ฃ๋Š”๋‹ค.

    4. ๋‹ซํžŒ ๊ด„ํ˜ธ โ€˜)โ€™,โ€™}โ€™,โ€™]โ€™๊ฐ€ ๋‚˜์˜ค๋ฉด ์Šคํƒ์—์„œ ๋บ€๋‹ค. pop() ์ด๋•Œ, ์Šคํƒ์˜ top์ด ๊ด„ํ˜ธ ์ง์ด ๋งž์•„์•ผํ•œ๋‹ค.

    5. ๋‹ซํžŒ ๊ด„ํ˜ธ๊ฐ€ ๋‚˜์™”์„ ๋•Œ ์Šคํƒ์ด ๋น„์–ด์žˆ๋‹ค๋ฉด ์˜ฌ๋ฐ”๋ฅธ ๊ด„ํ˜ธ ๋ฌธ์ž์—ด์ด ์•„๋‹ˆ๋‹ค.

    6. ๋ชจ๋“  ๊ณผ์ •์ด ๋๋‚œ ํ›„ ์Šคํƒ์ด ๋น„์–ด์žˆ์œผ๋ฏ€๋กœ ์˜ฌ๋ฐ”๋ฅธ ๊ด„ํ˜ธ ๋ฌธ์ž์—ด์ด๋‹ค. ๋งŒ์•ฝ ๋ชจ๋“  ๊ณผ์ •์ด ๋๋‚œ ํ›„ ์Šคํƒ์ด ๋น„์–ด์žˆ์ง€ ์•Š์œผ๋ฉด ์˜ฌ๋ฐ”๋ฅธ ๊ด„ํ˜ธ ๋ฌธ์ž์—ด์ด ์•„๋‹ˆ๋‹ค.

int check(char c,Node **top){
    switch (c) {
        case '(':
            push(top, 2);
            break;
        case '{':
            if(is_empty(*top))push(top, 1);
            else{
                if(peak(*top)==2){
                    printf("[๊ทœ์น™2]์‹คํŒจ\n");
                    return -1;
                }
                push(top, 1);
            }
            break;
        case '[':
            if(is_empty(*top))push(top, 0);
            else{
                if(peak(*top)!=0){
                    printf("[๊ทœ์น™1]์‹คํŒจ\n");
                    return -1;
                }
                push(top, 0);
            }
            break;
        case ')':
            if(is_empty(*top)){
                printf("[๊ทœ์น™5]์‹คํŒจ\n");
                return -1;
            }else if(peak(*top)!=2){
                printf("[๊ทœ์น™4]์‹คํŒจ\n");
                return -1;
            }
            pop(top);
            break;
        case '}':
            if(is_empty(*top)){
                printf("[๊ทœ์น™5]์‹คํŒจ\n");
            }else if(peak(*top)!=1){
                printf("[๊ทœ์น™4]์‹คํŒจ\n");
                return -1;
            }
            pop(top);
            break;
        case ']':
            if(is_empty(*top)){
                printf("[๊ทœ์น™5]์‹คํŒจ\n");
            }else if(peak(*top)!=0){
                printf("[๊ทœ์น™4]์‹คํŒจ\n");
                return -1;
            }
            pop(top);
            break;
        default:
            printf("์ž˜๋ชป ์ž…๋ ฅ ํ–ˆ์Šต๋‹ˆ๋‹ค.\n");
            break;
    }
    return 1;
}

int main(int argc, const char * argv[]) {

    Stack * top = NULL;
    int res = 0;
    char c;

    printf("๊ฐ’์„ ์ž…๋ ฅํ•ด์ฃผ์„ธ์š”. : ");
    while ((c = getchar()) && c != EOF && c!='\n') {
        res = check(c, &top);
        if(res==-1)break;
        if(peak(top)!=-1)printf("์Šคํƒ top : %c\n",bracket[peak(top)]);
    }

    if(res!=-1){
        if (is_empty(top)) {
            printf("\n==๊ด„ํ˜ธ ๊ฒ€์‚ฌ ์„ฑ๊ณต==\n");
        }else{
            printf("\n==[๊ทœ์น™6]์‹คํŒจ==\n");
        }
    }
}

์‡ ๋ง‰๋Œ€๊ธฐ

  • ๋ ˆ์ด์ €๋Š” ์—ฌ๋Š” ๊ด„ํ˜ธ์™€ ๋‹ซ๋Š” ๊ด„ํ˜ธ์˜ ์ธ์ ‘ํ•œ(์ธ๋ฑ์Šค ์ค‘์š”) ์Œ ()์œผ๋กœ ํ‘œํ˜„ํ•œ๋‹ค. ๋˜ํ•œ, ๋ชจ๋“  ()๋Š” ๋ฐ˜๋“œ์‹œ ๋ ˆ์ด์ €๋ฅผ ํ‘œํ˜„ํ•œ๋‹ค.

  • ์‡ ๋ง‰๋Œ€๊ธฐ์˜ ์™ผ์ชฝ ๋์€ (๋กœ, ์˜ค๋ฅธ์ชฝ ๋์€ ๋‹ซํžŒ ๊ด„ํ˜ธ)๋กœ ํ‘œํ˜„ํ•œ๋‹ค.

  • ()๊ฐ€ ๋‚˜์˜ฌ ๋•Œ๋งˆ๋‹ค ์Šคํƒ์— ๋“ค์–ด ์žˆ๋Š” (์˜ ๊ฐœ์ˆ˜๋ฅผ ์„ธ์–ด์ค€๋‹ค.

  • )๊ฐ€ ๋‚˜์™”์„ ๋•Œ๋Š” ๋ ˆ์ด์ €์ธ์ง€ ์‡ ๋ง‰๋Œ€๊ธฐ ์ธ์ง€ ๊ตฌ๋ถ„์„ ํ•ด์ค€๋‹ค.

  • ๋ ˆ์ด์ €๋Š” ํ•ญ์ƒ ๋ถ™์–ด์ง„ ์ƒํƒœ๋กœ ๋‚˜์˜ค๋ฏ€๋กœ ์Šคํƒ์˜ (์˜ ์ธ๋ฑ์Šค์™€ 1์ฐจ์ด๊ฐ€ ๋‚˜๋Š”์ง€ ํ™•์ธํ•ด์•ผํ•œ๋‹ค.

#include <iostream>
#include <stack>
#include <string>
using namespace std;

int main(){
    stack<int> s;

    int cnt=0;
    string ps;
    cin >> ps;

    for(int i=0;i<=ps.size();i++){
        if(ps[i]=='('){
            s.push(i);
        }else if(ps[i]==')'){
            if(i==s.top()+1){
                s.pop();
                cnt+=s.size();
            }else{
                s.pop();
                cnt+=1;
            }
        }
    }
    cout << cnt << "\n";
}

์—๋””ํ„ฐ

  • ์ปค์„œ๋Š” ๋ฌธ์žฅ์˜ ๋งจ ์•ž, ๋งจ ๋’ค, ์ค‘๊ฐ„ ์ž„์˜์˜ ๊ณณ์— ์œ„์ฐจํ•  ์ˆ˜ ์žˆ๋‹ค.

  • L : ์ปค์„œ๋ฅผ ์™ผ์ชฝ์œผ๋กœ ํ•œ์นธ ์˜ฎ๊น€

  • D : ์ปค์„œ๋ฅผ ์˜ค๋ฅธ์ชฝ์œผ๋กœ ํ•œ์นธ ์˜ฎ๊น€

  • B : ์ปค์„œ ์™ผ์ชฝ์— ์žˆ๋Š” ๋ฌธ์ž๋ฅผ ์‚ญ์ œ

  • P $ : $๋ผ๋Š” ๋ฌธ์ž๋ฅผ ์ปค์„œ ์˜ค๋ฅธ์ชฝ์— ์ถ”๊ฐ€

  • ์ปค์„œ๋ฅผ ๊ธฐ์ค€์œผ๋กœ ์™ผ์ชฝ ์Šคํƒ๊ณผ ์˜ค๋ฅธ์ชฝ ์Šคํƒ์œผ๋กœ ๋‚˜๋ˆ ์„œ ๋ฌธ์ œ๋ฅผ ํ’€ ์ˆ˜ ์žˆ๋‹ค.

    abc|xyz
    (|๋Š” ์ปค์„œ)
  • L ์™ผ์ชฝ์œผ๋กœ ์˜ฎ๊น€

    ab|cxyz
  • D ์˜ค๋ฅธ์ชฝ์œผ๋กœ ์˜ฎ๊น€

    abcx|yz
  • B ์™ผ์ชฝ ๋ฌธ์ž ์‚ญ์ œ

    ab|xyz
  • P$ $๋ฅผ ์ปค์„œ ์™ผ์ชฝ์— ์ถ”๊ฐ€ํ•˜๊ณ  ์ปค์„œ๋Š” $์˜ ์˜ค๋ฅธ์ชฝ์— ์œ„์น˜

    abcd|xyz

O(N^2)์—์„œ ์Šคํƒ์„ ์‚ฌ์šฉํ•˜๋ฉด O(N)์œผ๋กœ ์‹œ๊ฐ„๋ณต์žก๋„๊ฐ€ ์ค„์–ด๋“ ๋‹ค.

#include <cstdio>
#include <cstring>
#include <stack>
using namespace std;
char a[600000];
int main() {
    scanf("%s",a);
    stack<char> left, right;
    int n = strlen(a);
    for (int i=0; i<n; i++) {
        left.push(a[i]);
    }
    int m;
    scanf("%d",&m);
    while (m--) {
        char what;
        scanf(" %c",&what);
        if (what == 'L') {
            if (!left.empty()) {
                right.push(left.top());
                left.pop();
            }
        } else if (what == 'D') {
            if (!right.empty()) {
                left.push(right.top());
                right.pop();
            }
        } else if (what == 'B') {
            if (!left.empty()) {
                left.pop();
            }
        } else if (what == 'P') {
            char c;
            scanf(" %c",&c);
            left.push(c);
        }
    }
    while (!left.empty()) {
        right.push(left.top());
        left.pop();
    }
    while (!right.empty()) {
        printf("%c",right.top());
        right.pop();
    }
    printf("\n");
    return 0;
}

ํ›„์œ„ ํ‘œ๊ธฐ์‹

์ˆ˜์‹์˜ ํ‘œ๊ธฐ๋ฐฉ๋ฒ•

  • ์ „์œ„ ํ‘œ๊ธฐ๋ฒ• : ์—ฐ์‚ฐ์ž๋ฅผ ํ”ผ์—ฐ์‚ฐ์ž ์•ž์— ํ‘œ๊ธฐํ•˜๋Š” ๋ฐฉ๋ฒ• (+AB)

  • ์ค‘์œ„ ํ‘œ๊ธฐ๋ฒ• : ์—ฐ์‚ฐ์ž๋ฅผ ํ”ผ์—ฐ์‚ฐ์ž ์ค‘๊ฐ„์— ํ‘œ๊ธฐํ•˜๋Š” ๋ฐฉ๋ฒ• (A+B)

  • ํ›„์œ„ํ‘œ๊ธฐ๋ฒ• : ์—ฐ์‚ฐ์ž๋ฅผ ํ”ผ์—ฐ์‚ฐ์ž ๋’ค์— ํ‘œ๊ธฐํ•˜๋Š” ๋ฐฉ๋ฒ• (AB+)

์ˆ˜์‹์„ ์™ผ์ชฝ์—์„œ ์˜ค๋ฅธ์ชฝ์œผ๋กœ ์Šค์บ”ํ•˜์—ฌ

  1. ํ”ผ์—ฐ์‚ฐ์ž์ด๋ฉด ์Šคํƒ์— ์ €์žฅ

  2. ์—ฐ์‚ฐ์ž์ด๋ฉด ํ•„์š”ํ•œ ์ˆ˜๋งŒํผ์˜ ํ”ผ์—ฐ์‚ฐ์ž๋ฅผ ์Šคํƒ์—์„œ pop

  3. ์—ฐ์‚ฐ์˜ ๊ฒฐ๊ณผ๋ฅผ ๋‹ค์‹œ ์Šคํƒ์— ์ €์žฅ

์˜ˆ์ œ)82/3-32*+
01. push(8) ์Šคํƒ : 8
02. push(2) ์Šคํƒ : 8 2
03. second<-pop(2) first<-pop(8) push(first/second) ์Šคํƒ : 4
05. push(3) ์Šคํƒ : 4 3
06. second<-pop(3) first<-pop(4) push(first-second) ์Šคํƒ : 1
07. push(3) ์Šคํƒ : 1 3
08. push(2) ์Šคํƒ : 1 3 2
09. second<-pop(2) first<-pop(3) push(first*second) ์Šคํƒ : 1 6
10. second<-pop(6) first<-pop(1) push(first+second) ์Šคํƒ : 7

๊ตฌํ˜„์‹œ ์—ฐ์‚ฐ์ž๊ฐ€ ๋‚˜์™”์„ ๋•Œ pop์„ ๋‘๋ฒˆํ•  ์ˆ˜ ์žˆ๋Š”์ง€์™€ ๊ฐ™์€ ์กฐ๊ฑด์„ ๋”ฐ์ ธ์•ผํ•œ๋‹ค.

#include <stdio.h>
#include "stack_list.h"

int check(char c,  Stack **top){

    int a,b;
    if('0'<=c&& c<='9'){
        push(top, c-'0');
    }else{
        a = peak(*top);
        if(a==-1){
            printf("ํ”ผ์—ฐ์‚ฐ์ž์˜ ์ˆ˜๊ฐ€ ๋ถ€์กฑํ•ฉ๋‹ˆ๋‹ค.\n");
            return -1;
        }
        pop(top);
        b = peak(*top);
        if(b==-1){
            printf("ํ”ผ์—ฐ์‚ฐ์ž์˜ ์ˆ˜๊ฐ€ ๋ถ€์กฑํ•ฉ๋‹ˆ๋‹ค.\n");
            return -1;
        }
        pop(top);

        if(c=='+'){
            push(top, b+a);
        }else if(c=='/'){
            push(top, b/a);
        }else if(c=='*'){
            push(top, b*a);
        }else if(c=='-'){
            push(top, b-a);
        }else{
            push(top, b%a);
        }
    }
    return peak(*top);
}

int main(int argc, const char * argv[]) {
    Stack * head=NULL;
    char c;
    int result=0;
    while ((c = getchar()) && c != EOF && c!='\n') {
        result=check2(c,&head);
        if(result==-1)break;
    }
    if(result!=-1)printf("%d\n",result);
    else printf("์‹คํŒจ\n");
    return 0;
}

์ค‘์œ„ ํ‘œ๊ธฐ์‹ โ†’ ํ›„์œ„ ํ‘œ๊ธฐ์‹

  1. ์ˆ˜์‹์˜ ๊ฐ ์—ฐ์‚ฐ์ž์— ๋Œ€ํ•ด์„œ ์šฐ์„ ์ˆœ์œ„์— ๋”ฐ๋ผ ๊ด„ํ˜ธ๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ๋‹ค์‹œ ํ‘œํ˜„ํ•œ๋‹ค. ((A*B)-(C/D))

  2. ๊ฐ ์—ฐ์‚ฐ์ž๋ฅผ ๊ทธ์— ๋Œ€์‘ํ•˜๋Š” ์˜ค๋ฅธ์ชฝ ๊ด„ํ˜ธ์˜ ๋’ค๋กœ ์ด๋™์‹œํ‚จ๋‹ค.((A B)* (C D)/)-

  3. ๊ด„ํ˜ธ ์ œ๊ฑฐ AB*CD/-

์•Œ๊ณ ๋ฆฌ์ฆ˜ ๊ฐœ์š”

  1. ์™ผ์ชฝ ๊ด„ํ˜ธ๋ฅผ ๋งŒ๋‚˜๋ฉด ๋ฌด์‹œ

  2. ํ”ผ์—ฐ์‚ฐ์ž๋ฅผ ๋งŒ๋‚˜๋ฉด ์ถœ๋ ฅ

  3. ์—ฐ์‚ฐ์ž๋ฅผ ๋งŒ๋‚˜๋ฉด ์Šคํƒ์— ์‚ฝ์ž…

  4. ์˜ค๋ฅธ์ชฝ ๊ด„ํ˜ธ๋ฅผ ๋งŒ๋‚˜๋ฉด ์Šคํƒ pop

  5. ์ˆ˜์‹์ด ๋๋‚˜๋ฉด ์Šคํƒ์ด ๊ณต๋ฐฑ์ด ๋  ๋•Œ๊นŒ์ง€ pop

#include <stdio.h>
#include "stack_array.h"

void convert(char c,StackType *s){
    if(c=='(')return;
    if('0'<=c&&c<='9')printf("%d",c-'0');
    else if(c==')')printf("%c",pop(s));
    else push(s, c);
}

int main(int argc, const char * argv[]) {
    char c;
    Stack s;
    init(&s);
    while ((c = getchar()) && c != EOF) {
        if(c=='\n')break;
        convert(c, &s);
    }
    while((&s)->top!=-1){
        printf("%c",pop(&s));
    }

    return 0;
}

Last updated

Was this helpful?