zoukankan      html  css  js  c++  java
  • HDOJ 4964 Emmet


    递归语法翻译。。。

    Emmet

    Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)
    Total Submission(s): 138    Accepted Submission(s): 44


    Problem Description
    For every programmer, coding HTML & CSS is a very boring thing.

    For example, writing an html tag <div> with id "div1" and class "col-md-3", you must write an html file like this:

        <div id = "div1" class = "col3">
        ...
        </div>
    Too much unnecessary coding!!!

    For convenience, some Web programmer develop a vim plugin -- Emmet. By this tool, the programmer just need code "div#div1.col3" and then Emmet would transform it to "<div id = "div1" class = "col3"></div>". It is very coollllll! Now you task is to write a program to perform this transformation.

    Here are more details about you task:

    1.Handle multilevel tag.
      "div>p>span" means there are 3 tags and tag <p> is in the tag "div", tag <span> is in the tag "p".
      So, the right answer is "<div><p><span></span></p></div>"

    2.  Every tag may have zero or one id and any amount of classes.
      A string (only consisting of letters and digits) after '#' is an id name.
      A string (only consisting of letters and digits) after '.' is a class name.
      If a tag has id and classes at the same time, you must output the id first.
      If a tag has more than one class, you must output them by the order according to the input.
      For example
      "div.aa#bb.cc.ee>p#g>span.d" =>
      <div id="bb" class="aa cc ee">
        <p id="g">
          <span class="d"></span>
        </p>
      </div>"

    3.Handle parentheses.
      Use parentheses to deal with sibling relation among tags!
      For example
      <div id="bb" class="aa cc ee">
        <p id="g1"><span class="d1"></span></p>
        <p id="g2"><span class="d2"></span></p>
        <p id="g3"><span class="d3"></span></p>
      </div>
      can be obtained by "div.aa#bb.cc.ee>(p#g1>span.d1)(p#g2>span.d2)(p#g3>span.d3)"
      If the input string contains parentheses, the rightmost ‘)’ will be the last character of this string.

    4.Handle symbol ‘*’
    At the end of a tag, you may see a suffix "*%d". It indicates that this tag would be repeated "%d" times.
      For example
      ul#id1>li.classA*3>p*2 =>
      <ul id="id1">
        <li class="classA">
          <p></p>
          <p></p>
        </li>
        <li class="classA">
          <p></p>
          <p></p>
        </li>
        <li class="classA">
          <p></p>
          <p></p>
        </li>
      </ul>
     

    Input
    The first line of input contains an integer N (N<=50), indicating the number of strings you need to transform.

    The following N lines, each consists of an input string. No string has more than 120 chars and the result would not have more than 1000 chars. Tag name, class name and id only contain English letters and digits. It is guaranteed that the input string is valid.
     

    Output
    Output N lines each consisting of a string that is the result of the transformation. More details about the output format can be seen from the sample output. You should follow the output format strictly. No extra space or new line character is allowed in the output.
     

    Sample Input
    4 div>p>span div.aa#bb.cc.ee>p#g>span.d div.aa#bb.cc.ee>(p#g1>span.d1)(p#g2>span.d2)(p#g3>span.d3) ul#id1>li.classA*3>p*2
     

    Sample Output
    <div><p><span></span></p></div> <div id="bb" class="aa cc ee"><p id="g"><span class="d"></span></p></div> <div id="bb" class="aa cc ee"><p id="g1"><span class="d1"></span></p><p id="g2"><span class="d2"></span></p><p id="g3"><span class="d3"></span></p></div> <ul id="id1"><li class="classA"><p></p><p></p></li><li class="classA"><p></p><p></p></li><li class="classA"><p></p><p></p></li></ul>
     

    Author
    SYSU
     

    Source
     



    #include <iostream>
    #include <cstring>
    #include <cstdio>
    #include <algorithm>
    #include <string>
    
    using namespace std;
    
    struct Node
    {
        string head,context,end;
        void Uion(Node a)
        {
            context=a.head+a.context+a.end;
        }
    };
    
    string cmd,ans;
    
    Node get_Node(int l,int r)
    {
        string name="",id="",cls="";
        int i;
        for(i=l;i<=r;i++)
        {
            if(cmd[i]=='.'||cmd[i]=='#'||cmd[i]=='*') break;
            name+=cmd[i];
        }
        while(i<=r)
        {
            if(cmd[i]=='*') break;
            if(cmd[i]=='.')
            {
                i++;
                if(cls.length()) cls+=" ";
                for(;i<=r;i++)
                {
                    if(cmd[i]=='.'||cmd[i]=='#'||cmd[i]=='*') break;
                    cls+=cmd[i];
                }
            }
            else if(cmd[i]=='#')
            {
                i++;
                if(id.length()) id+=" ";
                for(;i<=r;i++)
                {
                    if(cmd[i]=='.'||cmd[i]=='#'||cmd[i]=='*') break;
                    id+=cmd[i];
                }
            }
        }
        Node ret;
        ret.head="<"+name;
        if(id.length()) ret.head+=" id=""+id+""";
        if(cls.length()) ret.head+=" class=""+cls+""";
        ret.head+=">";
        ret.end="</"+name+">";
        return ret;
    }
    
    int get_num(int L,int R)
    {
        int i,ret=0;
        for(i=L;i<=R;i++)
        {
            if(cmd[i]=='*') break;
        }
        i++;
        for(;i<=R;i++)
        {
            ret=ret*10+cmd[i]-'0';
        }
        return ret;
    }
    
    Node get_cmd(int L,int R)
    {
        Node ans;
        if(L>R) return ans;
        if(cmd[L]!='(')
        {
            int r=L;
            while(r<=R&&cmd[r]!='>')
                r++;
            int num=get_num(L,r-1);
            ans=get_Node(L,r-1);
    
            Node temp=get_cmd(r+1,R);
    
            ans.Uion(temp);
            if(num>1)
            {
                string loop=ans.context;
                for(int i=1;i<num;i++)
                {
                    loop+=ans.end+ans.head+ans.context;
                }
                ans.context=loop;
            }
        }
        else
        {
            int sum=0,last=L;
            for(int i=L;i<=R;i++)
            {
                if(cmd[i]=='(') sum++;
                else if(cmd[i]==')') sum--;
                if(sum==0)
                {
                    Node temp=get_cmd(last+1,i-1);
                    last=i+1;
                    if(ans.head.length()==0)
                    {
                        ans=temp;
                    }
                    else
                    {
                        ans.context+=ans.end+temp.head+temp.context;
                        ans.end=temp.end;
                    }
                }
            }
        }
        return ans;
    }
    
    int main()
    {
        int T_T;
        scanf("%d",&T_T);
        while(T_T--)
        {
            cin>>cmd;
            int len=cmd.length();
            Node ans=get_cmd(0,len-1);
            cout<<ans.head<<ans.context<<ans.end<<endl;
        }
        return 0;
    }
    



  • 相关阅读:
    云时代架构阅读笔记十一——分布式架构中数据一致性常见的几个问题
    云时代架构阅读笔记十——支付宝架构师眼中的高并发架构
    云时代架构阅读笔记九——Disruptor无锁框架为啥这么快
    云时代架构阅读笔记八——JVM性能调优
    lightoj 1024 (高精度乘单精度)
    lightoj 1023
    lightoj 1022
    codeforces 260 div2 C题
    codeforces 260 div2 B题
    codedorces 260 div2 A题
  • 原文地址:https://www.cnblogs.com/blfshiye/p/5029141.html
Copyright © 2011-2022 走看看