uva11234 Expressions(이차 트리 만들기 + 차원 반복)

학교에 돌아온 지 이틀이 되었어요. 첫 번째 문제인 셈이죠. 손이 좀 서툴러서 다른 사람의 문제풀이를 봤는데...
여름방학 동안 문제 풀이에 힘썼어요. 파이팅...
분석: 제목의 뜻은 자모의 순서를 다시 배열하여 대열의 방식으로 그들이 앞에서 말한 창고 출납 방식에 따라 실현한 표현식을 실현하는 것이다. 간단하게 말하면
두 갈래 나무를 세우고 그 층을 훑어보고 역순으로 출력하는 것이다.
코드:
<span style="font-size:18px;">#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<stack>
using namespace std;
char a[10005];
struct node
{
    char val;
    node* l;
    node* r;
};
char ans[10005];
int sum;
int bfs(node *root)
{
    int front = 0; 
    int rear = 1;
    sum=0;
    node *q[10005];
    q[0] = root;
    while(front<rear)
    {
        node *u = q[front++];
        ans[sum++] = u->val;
        if(u->l!=NULL)
          q[rear++] = u->l;
        if(u->r!=NULL)
          q[rear++] = u->r;
    }
    return 0;
}
int main()
{
    int T;
    int i,j;
    node* m,*n;
    stack<node*>s;
    scanf("%d",&T);
    
    while(T--)
    {
        scanf("%s",a);
        int len = strlen(a);
        for(i=0; i<len; i++)
        {
            if(a[i]>='a'&&a[i]<='z')
            {
                node *p = new node;
                p->val = a[i];
                p->l = p->r = NULL;
                s.push(p);
            } 
            else
            {
                m=s.top();
                s.pop();
                n=s.top();
                s.pop();
                node *q = new node;
                q->val = a[i];
                q->l = n;
                q->r = m;
                s.push(q);
            }
        }
        bfs(s.top()); 
	    for(i=sum-1; i>=0; i--)
	    	printf("%c",ans[i]);
	    puts("");
    }
	return 0;
}</span>

좋은 웹페이지 즐겨찾기