codeforces#P1156G. Optimizer
Optimizer
Description
Let's analyze a program written on some strange programming language. The variables in this language have names consisting of $1$ to $4$ characters, and each character is a lowercase or an uppercase Latin letter, or a digit. There is an extra constraint that the first character should not be a digit.
There are four types of operations in the program, each denoted by one of the characters: $, ^, # or &.
Each line of the program has one of the following formats:
- <lvalue>=<rvalue>, where <lvalue> and <rvalue> are valid variable names;
- <lvalue>=<arg1><op><arg2>, where <lvalue>, <arg1> and <arg2> are valid variable names, and <op> is an operation character.
The program is executed line-by-line, and the result of execution is stored in a variable having the name res. If res is never assigned in the program, then the result will be equal to the value of res before running the program.
Two programs are called equivalent if no matter which operations do characters $, ^, # and & denote (but, obviously, performing the same operation on the same arguments gives the same result) and which values do variables have before execution of program, the value of res after running the first program is equal to the value of res after running the second program (the programs are executed independently).
You are given a program consisting of $n$ lines. Your task is to write a program consisting of minimum possible number of lines that is equivalent to the program you are given.
The first line contains one integer $n$ ($1 \le n \le 1000$) — the number of lines in the program.
Then $n$ lines follow — the program itself. Each line corresponds to the format described in the statement and has no extra whitespaces.
In the first line print $k$ — the minimum number of lines in the equivalent program.
Then print $k$ lines without any whitespaces — an equivalent program having exactly $k$ lines, in the same format it is described in the statement.
Input
The first line contains one integer $n$ ($1 \le n \le 1000$) — the number of lines in the program.
Then $n$ lines follow — the program itself. Each line corresponds to the format described in the statement and has no extra whitespaces.
Output
In the first line print $k$ — the minimum number of lines in the equivalent program.
Then print $k$ lines without any whitespaces — an equivalent program having exactly $k$ lines, in the same format it is described in the statement.
Samples
4
c=aa#bb
d12=c
res=c^d12
tmp=aa$c
2
aaaa=aa#bb
res=aaaa^aaaa
2
max=aaaa$bbbb
min=bbbb^aaaa
0