zoukankan      html  css  js  c++  java
  • joj 1329 二叉树

    给出中根序列和后根序列求路径值最小的叶节点,各种队,各种栈(话说一开始理解错题了,英语不好的悲哀)

    #include<iostream>
    #include<stack>
    #include<queue>
    using namespace std;
    int mmaaxx;
    int k;
    void tree(stack<int> s1,stack<int> s2,int m)
    {
         if(s1.size()==1&&s2.size()==1)
         {
            if((m+s1.top())<mmaaxx)
            {
               mmaaxx=m+s1.top();
               k=s1.top();
            }
            return ;
         }
         if(s1.size()==0)
            return;
         int t=s2.top();
         s2.pop();
         stack<int> p1,p2,q1,q2;
         while(s1.top()!=t)
         {
             p1.push(s1.top());
             p2.push(s2.top());
             s1.pop();
             s2.pop();
         }    
         s1.pop();
         while(p1.size()!=0)
         {
            q1.push(p1.top());
            q2.push(p2.top());
            p1.pop();
            p2.pop();
         }
         tree(s1,s2,m+t);
         tree(q1,q2,m+t);
    }
    int main()
    {
        int total_case,iii;
        scanf("%d",&total_case);
        getchar();
        for(iii=0;iii<total_case;iii++)
        {
             k=0;
             mmaaxx=10000;
             char str1[500],str2[500],str[500];
             stack<int> s1,s2;
             queue<int> s;
             int a;
             int i=0,j=0;
             gets(str1);
             gets(str2);
             for(i=0;str1[i]!='\0';i++)
             {
                if(str1[i]==32)
                {
                   str[j]='\0';
                   s1.push(atoi(str));
                   j=0;
                }
                else
                {
                    str[j]=str1[i];
                    j++;
                }
             }
             str[j]='\0';
             s1.push(atoi(str));
             j=0;
             for(i=0;str2[i]!='\0';i++)
             {
                if(str2[i]==32)
                {
                   str[j]='\0';
                   s2.push(atoi(str));
                   j=0;
                }
                else
                {
                    str[j]=str2[i];
                    j++;
                }
             }
             str[j]='\0';
             s2.push(atoi(str));
             j=0;
             tree(s1,s2,0);
             printf("%d\n",k);
        }
    }

  • 相关阅读:
    haproxy+keepalived配置haproxy反向代理的高可用
    正则表达式
    logstash 中multiline插件的用法
    logtash 接收多配置文件
    Debian 8 升级到 9 Debian 9 How to upgrade Debian 8 Jessie to Debian 9 Stretch
    YOLO object detection with OpenCV
    快速 图片颜色转换迁移 Color Transfer Opencv + Python
    对抗网络GAN的应用实例
    nvflash 报错解决
    卷积神经网络(CNN)在语音识别中的应用
  • 原文地址:https://www.cnblogs.com/dchipnau/p/4985947.html
Copyright © 2011-2022 走看看