# **Logic Solver**

# Rules:

- 1. Plagiarism is forbidden.
- 2. Write your program with C++.

## Problem Definition:

- ✓ You are given a combinational circuit with several logic gates, where the circuit has no feedback loops.
- √ The circuit is composed of three kinds of logic gates. They are INV(NOT), NAND and NOR respectively. The following are those gates' truth tables.



- ✓ There are three types of wires: input wires, connection wires, and output wires. Input wires carry initial input logic and are not connected to any gate's output; in other words, they have no fan-in gates. In contrast, output wires carry output logic and are not connected to any gate's input, meaning they have no fan-out gates.
- √ Solve the logic on those output wires.

# I/O Format:

## **Example 1: Input:**

```
W1 W2 W3
0 1 0
W11 W12 W13
INV g1 W1 W4
INV g2 W2 W5
NAND g3 W4 W5 W6
INV g4 W5 W7
NOR g5 W4 W3 W8
INV g6 W6 W9
NOR g7 W6 W7 W10
NAND g8 W7 W8 W11
NOR g9 W9 W10 W12
NOR g10 W10 W8 W13
```

### The circuit be like:



### Output:

w11 1 w12 1 w13 1

### Explanation:

- ✓ The input wires of above circuit are w1, w2 and w3. The following line stands for the initial logics of this circuit with the same order of input wires.
- ✓ The output wires of above circuit are w11, w12 and w13. Gate name
- ✓ The netlist structure of INV:

INV g1 w1 w4 Out-connection-wire

✓ The netlist structure of NAND and NOR:



# Constraints:

✓ Follow the given output wires order to print out the answer