loj#P2644. 「CTSC2001」逻辑电路最优设计
「CTSC2001」逻辑电路最优设计
题目描述
W 教授在 T 大学计算机系里开了一门「数字逻辑」课,主要讲授如何设计逻辑电路。这一天,W 教授布置了一个实验:设计并实现一个 端输入、 端输出的逻辑译码电路。设计这样的电路原本并不困难,但是,教授给出了如下的要求:
- 只允许使用 端输入、 端输出的门电路作为实现电路的组件,而且可用门电路的种类和数目都已给定;
- 使用最少数目的门电路。
这两个要求难倒了全系的同学,于是,Q 同学找到了正在参加 CTSC(中国队选拔赛)的你,希望你能帮忙编写一个程序,自动找出符合要求的连接方式。
在数字逻辑中,所有信号都可以看作只有两个值:「高电平」和「低电平」,分别用 和 来表示。
一个门电路元件的特性由其输入/输出功能表唯一给出,所谓功能表,就是输入信号电平与输出信号电平之间的关系表。比如,「与门」的符号和功能表如下图所示:
X | Y | S |
---|---|---|
0 | 0 | 0 |
1 | ||
0 | 1 | |
1 | 1 |
上图中,如果「与门」的两个输入端 X 和 Y 都是高电平 ,则输出端 S 也是高电平 ,否则,输出端 S 是低电平 。
假定,本次实验提供的门电路都具有输入对称性,即交换两个输入端的信号,输出不变。但是,如果门电路的输入端悬空(即没有加输入信号),则输出无意义。
在连接电路的过程中,一个门电路的输出端可以将信号送到其他多个元件的输入端;而门电路的一个输入端则只能接收来自一个输出端的信号。如下图所示:
其中,前两个连接方式是允许的,最后一个是不允许的。
另外,规定信号必须单向传输,即一个门电路的输出不能直接或间接通过其他门电路回到同一门电路的输入端。如下图所示即为两种不允许的连接方式:
要求你设计的译码电路是一个有四个输入端和四个输出端的逻辑电路,该译码电路的输入和输出关系通过功能表给出,即给出每种输入组合下的四个输出端的情况。显然,一共有 种输入组合。比如,一个由前述「与门」构成的 输入, 输出的简单译码电路如下图所示(其中,A1, A2 是输入端,Y1, Y2 是输出端)
A1 | A2 | Y1 | Y2 |
---|---|---|---|
0 | 0 | 0 | |
1 | |||
0 | 1 | ||
1 | 1 |
输入格式
第一行为一个正整数 ,表示元件的种类数,其后有连续的 行,每行描述一种元件。对正整数 :
第 行有四个以空格隔开的整数,依次为:。
其中,正整数 表示第 种元件的数目( 即这种元件的种类编号),所有元件的数目之和不会超过 (用于实验的经费并不充足)。 表示两个输入端分别为 和 时的输出,即 是三个非 即 的数,分别表示在两个输入端均为 ;两个输入端一个为 另一个为 ;以及两个输入端均为 的时候,该元件的输出。
第 到第 行,表示需组成的集成电路的功能表,每行有 个数,分别为 或 。其中,前四个数依次对应四个输入端(编号为 )的信号,不存在两行的前四个数完全相同;而后面四个数则对应在各输入端信号为前四个数时,四个输出端依次应输出的信号。
输出格式
第一行为一个单词,Yes
或 No
,如果存在符合要求的设计方案,则为 Yes
,否则为 No
。
如果第一行是 No
,则输出结束。
否则第二行只有一个非负整数 ,表示最少需要的门电路数目。下面 行分别给出每个门电路在电路中的连接情况的描述。每行有四个以空格隔开的正整数:,其中 表示该门电路的编号(所有用到的门电路按 编号, 的编号用来表示四个输入端); 表示该元件的种类编号(按照输入文件中的顺序由 编号); 和 分别表示接入该元件的两个输入端的门电路或译码电路输入端的编号(其中,)。
最后一行有四个正整数,表示组成的译码电路的四个输出端分别所接的元件的编号(在 之间)。
1
5 0 1 0
0 0 0 0 0 0 0 0
1 0 0 0 1 0 0 0
0 1 0 0 1 1 0 0
1 1 0 0 0 1 0 0
0 0 1 0 0 1 1 0
1 0 1 0 1 1 1 0
0 1 1 0 1 0 1 0
1 1 1 0 0 0 1 0
0 0 0 1 0 0 1 1
1 0 0 1 1 0 1 1
0 1 0 1 1 1 1 1
1 1 0 1 0 1 1 1
0 0 1 1 0 1 0 1
1 0 1 1 1 1 0 1
0 1 1 1 1 0 0 1
1 1 1 1 0 0 0 1
Yes
3
5 1 2 1
6 1 3 2
7 1 4 3
5 6 7 4