mirror of
https://github.com/TheAlgorithms/Python.git
synced 2025-01-23 18:53:43 +00:00
f4ff73b1bd
* Converted tests into doctests * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * Removed commented code * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci --------- Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
40 lines
930 B
Python
40 lines
930 B
Python
"""
|
|
An IMPLY Gate is a logic gate in boolean algebra which results to 1 if
|
|
either input 1 is 0, or if input 1 is 1, then the output is 1 only if input 2 is 1.
|
|
It is true if input 1 implies input 2.
|
|
|
|
Following is the truth table of an IMPLY Gate:
|
|
------------------------------
|
|
| Input 1 | Input 2 | Output |
|
|
------------------------------
|
|
| 0 | 0 | 1 |
|
|
| 0 | 1 | 1 |
|
|
| 1 | 0 | 0 |
|
|
| 1 | 1 | 1 |
|
|
------------------------------
|
|
|
|
Refer - https://en.wikipedia.org/wiki/IMPLY_gate
|
|
"""
|
|
|
|
|
|
def imply_gate(input_1: int, input_2: int) -> int:
|
|
"""
|
|
Calculate IMPLY of the input values
|
|
|
|
>>> imply_gate(0, 0)
|
|
1
|
|
>>> imply_gate(0, 1)
|
|
1
|
|
>>> imply_gate(1, 0)
|
|
0
|
|
>>> imply_gate(1, 1)
|
|
1
|
|
"""
|
|
return int(input_1 == 0 or input_2 == 1)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
import doctest
|
|
|
|
doctest.testmod()
|