锘??xml version="1.0" encoding="utf-8" standalone="yes"?>欧美激情精品久久久久久久,99久久做夜夜爱天天做精品,久久久噜噜噜久久http://www.shnenglu.com/lvlawliet/category/17991.htmlVIMzh-cnWed, 26 Oct 2011 02:25:30 GMTWed, 26 Oct 2011 02:25:30 GMT60JOJ1037錛歄perandhttp://www.shnenglu.com/lvlawliet/archive/2011/10/25/159078.htmlLLawlietLLawlietTue, 25 Oct 2011 11:53:00 GMThttp://www.shnenglu.com/lvlawliet/archive/2011/10/25/159078.htmlhttp://www.shnenglu.com/lvlawliet/comments/159078.htmlhttp://www.shnenglu.com/lvlawliet/archive/2011/10/25/159078.html#Feedback0http://www.shnenglu.com/lvlawliet/comments/commentRss/159078.htmlhttp://www.shnenglu.com/lvlawliet/services/trackbacks/159078.html

Professor Maple teaches mathematics in a university. He have invented a function for the purpose of obtaining the operands from an expression. The function named op(i,e) can be described as follows: The expression e may be divided into sub-expression(s) by the operator, which has the lowest priority in the expression. For example, the expression “a*b+b*c+c*d” should be divided into three sub-expressions “a*b”, “b*c” and “c*d”, because the operator “+” has the lowest priority. The purpose of this function is to extract the ith sub-expression as the result. So, in the example above, op(2,e)=b*c.

If we regard the sub-expression as the main expression, it might be divided again and again. Obviously, the dividing process is recursive. As you see, the following example is much more complex:

Let p:=a^b*c+(d*c)^f*z+b
op(1,op(1,op(2,p)))=(d*c)
op(1,op(1,op(1,op(2,p))))=d*c
op(2,op(2,p))=z
op(3,p)=b
op(1,op(3,p))=b

Professor Maple is so lazy that he would leave the work to computer rather than do it himself, when the expression is long and complicated. Of course, without your program, the computer won’t work out the result automatically.

Input

The input file contains several test cases. The last test case in the input file is followed by a line containing a symbol “*”, indicating the end of the input data. Each test case consists of two parts. The first part describes the expression, while the second part contains several questions, which should be calculated according to the expression.

The first line of each test case contains an expression consists of the expression name, “:=” and the content of the expression. The expression name is a lowercase. And the content is composed by lowercases and operators “+”, “(”, “)”, “*” and “^”. For example, here is a valid expression, p:=a^b*c+(d*c)^f*z+b. Among those operators, “(” and “)” have the highest priority. The operator “^” has a lower priority, and then “*”. The priority of the operator “+” is the lowest.

The second line of each test case contains an integer n indicating n questions based on the above expression. This is followed by n lines. Each of them contains the description of one question, which consists of integers. For example, the question with three integers “2 1 1” describes the function op(1,op(1,op(2,e))). To compute this function, we have to keep to the following sequence: First, according to the first integer 2, divide the expression and extract the 2nd sub-expression. Then, according to the second integer 1, divide the sub-expression and extract the 1st one. Finally, according to the third integer 1, divide the outcome again, and extract the result.

Output

For each test case, display the expression name and a colon on the first line. Then display the result of each question on a line. The layout of the output is shown in the sample output.

You may assume that all expressions and functions are always valid.

Display a blank line between test cases.

Sample Input

p:=a^b*c+(d*c)^f*z+b 
4
2 1 1
2 2
3
3 1
a:=(x+y)
3
1
1 2
1 2 1
*

Sample Output

Expression p: 
op(1,op(1,op(2,p)))=(d*c)
op(2,op(2,p))=z
op(3,p)=b
op(1,op(3,p))=b

Expression a:
op(1,a)=x+y
op(2,op(1,a))=y
op(1,op(2,op(1,a)))=y


妯℃嫙棰橈紝澶勭悊濂藉師瀛楃涓茬殑浼樺厛綰у氨琛屼簡銆?br />浠g爜錛?br />
#include <iostream>
#include 
<cstring>
#include 
<cstdio>
using namespace std;

int find(char c)
{
    
if (c == '(' || c == ')'return 4;
    
if (c == '^'return 3;
    
if (c == '*'return 2;
    
if (c == '+'return 1;
    
return 1000;
}

char s[101];
string e;
int n, i, j, k, p[101], r[101], v[101], head, tail, x, ri, d = 0;

int main()
{
    
while (scanf("%s", s), s[0!= '*')
    {
        
if (d++) puts("");
        head 
= 0;
        e 
= "";
        
while (s[head] != ':')
          e 
+= s[head++];
        head 
+= 2;
        printf(
"Expression %s:\n", e.c_str());
        tail 
= strlen(s) - 1;
        x 
= 0;
        
for (i = head; i <= tail; ++i)
        {
            
if (s[i] == ')') x -= 4;
            v[i] 
= find(s[i]) + x;
            
if (s[i] == '(') x += 4;
        }
        scanf(
"%d\n"&k);
        
for (i = 0; i < k; ++i)
        {
            ri 
= 0;
            
int head1 = 3, min1, t;
            tail 
= strlen(s);
            
char c;
            
while ((c = getchar()) != '\n')
            {
                cin.putback(c);
                scanf(
"%d"&n);
                r[ri
++= n;
                min1 
= 1000;
                
for (j = head1; j < tail; ++j)
                  
if (v[j] < min1) min1 = v[j];
                
if (s[head1] == '(' && s[tail - 1== ')' && min1 == v[head1])
                {
                    head1
++;
                    tail
--;
                }
                
else
                  
if (head1 + 1 == tail){}
                
else
                {
                    p[
0= head1 - 1;
                    
for (j = head1, t = 1; j < tail; ++j)
                      
if (v[j] == min1)
                      {
                          p[t
++= j;
                      }
                    p[t] 
= tail;
                    head1 
= p[n - 1+ 1;
                    tail 
= p[n];
                }
            }
            
for (j = ri - 1; j >= 0--j)
              printf(
"op(%d,", r[j]);
            printf(
"%s", e.c_str());
            
for (j = 0; j < ri; ++j)
              printf(
")");
            printf(
"=");
            
for (j = head1; j < tail; ++j)
                printf(
"%c", s[j]);
            puts(
"");
        }
    }
    
return 0;
}


LLawliet 2011-10-25 19:53 鍙戣〃璇勮
]]>
久久国产AVJUST麻豆| 久久精品成人| 久久久久高潮毛片免费全部播放 | 精品无码久久久久久久动漫| 91精品日韩人妻无码久久不卡| 久久精品国产清自在天天线| 麻豆av久久av盛宴av| 国产精品美女久久久久| 日本久久中文字幕| 69久久精品无码一区二区| 亚洲国产成人久久综合区| 色婷婷综合久久久久中文一区二区 | 久久久无码精品亚洲日韩按摩 | a级毛片无码兔费真人久久| 久久综合久久综合九色| 日日狠狠久久偷偷色综合免费| 狠狠综合久久AV一区二区三区| 国产精品免费久久久久影院| 亚洲AV无码一区东京热久久| 久久亚洲国产精品123区| AV无码久久久久不卡蜜桃 | 久久无码AV一区二区三区| 久久综合欧美成人| 久久久久久毛片免费播放| 亚洲国产精品无码久久青草| www.久久热| 久久不见久久见免费视频7| 久久婷婷人人澡人人爽人人爱| 久久婷婷五月综合色99啪ak| 国产—久久香蕉国产线看观看 | 精品久久久久久国产免费了| 99久久人妻无码精品系列蜜桃| 色88久久久久高潮综合影院| 久久亚洲国产成人影院| 久久青青国产| 久久亚洲天堂| 久久国内免费视频| 一本久久a久久精品综合香蕉| 午夜精品久久影院蜜桃| 国产欧美久久久精品影院| 国产精品久久婷婷六月丁香|