设计一个三变量奇偶检验器,要求:当输入变量a,b,c中有奇数个数为1时,输出为1,否则为0,用与非门实现
时间: 2024-04-21 19:28:13 浏览: 170
三变量奇偶检验器可以使用以下的逻辑电路实现:将输入变量a、b、c分别与非门相连,再将它们的输出通过一个与门相连,输出即为奇偶检验器的结果。
具体电路图如下:
![image](https://user-images.githubusercontent.com/38183218/137140163-4e7d5c25-9d67-4e7c-a2cc-8d3b9a3d36d5.png)
这个电路图中,三个非门分别将输入的三个变量取反,接着将三个非门的输出通过与门进行“与”运算,最终得到奇偶检验器的结果。
当输入变量a、b、c中有奇数个数为1时,它们的取反结果中有偶数个0和奇数个1,所以它们的与运算结果为0,此时与门的输出为0。
当输入变量a、b、c中有偶数个数为1时,它们的取反结果中有偶数个1和奇数个0,所以它们的与运算结果为1,此时与门的输出为1。
因此,这个电路可以实现三变量奇偶检验器的功能。
相关问题
设计一个三变量奇偶检验器,要求:当输入变量a,b,c中有奇数个数为1时,输出为1,否则为0,用与非门实现,写出函数表达式
好的,根据要求,我们可以列出三个输入变量的真值表如下:
| a | b | c | 输出 |
|---|---|---|------|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 1 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 1 |
我们可以发现,当输入变量中有奇数个1时,输出为1,否则为0。接下来,我们需要用与非门来实现这个三变量奇偶检验器。
根据与非门的定义,当且仅当所有输入变量都为1时,与非门的输出为0,否则为1。因此,我们可以使用三个与非门来实现这个三变量奇偶检验器,如下所示:
输出 = (a NOR b) NOR c
其中,NOR表示逻辑与非运算符,即当且仅当所有输入变量都为1时,输出为0,否则为1。
这个三变量奇偶检验器的函数表达式可以写成:
输出 = (¬a ∧ ¬b) ∧ ¬c
其中,¬表示逻辑非运算符,即当输入变量为1时,输出为0,否则为1。
三个线程 第一个获取输入,统计奇偶数个数,满足3个,唤醒2,3线程 第二个输出3个偶数 第三个输出3个奇数,使用条件变量
好的,这是一个比较典型的线程同步问题,可以使用条件变量和互斥锁来实现。下面是一个可能的实现:
```c++
#include <iostream>
#include <thread>
#include <mutex>
#include <condition_variable>
using namespace std;
mutex mtx;
condition_variable cv;
int count_even = 0;
int count_odd = 0;
void input_thread()
{
while (true)
{
int num;
cin >> num;
unique_lock<mutex> ul(mtx);
if (num % 2 == 0)
{
++count_even;
if (count_even == 3)
{
count_even = 0;
cv.notify_all();
}
}
else
{
++count_odd;
if (count_odd == 3)
{
count_odd = 0;
cv.notify_all();
}
}
}
}
void output_even_thread()
{
while (true)
{
unique_lock<mutex> ul(mtx);
cv.wait(ul, []{ return count_even == 3; });
for (int i = 0; i < 3; ++i)
{
cout << i * 2 << " ";
}
cout << endl;
}
}
void output_odd_thread()
{
while (true)
{
unique_lock<mutex> ul(mtx);
cv.wait(ul, []{ return count_odd == 3; });
for (int i = 0; i < 3; ++i)
{
cout << i * 2 + 1 << " ";
}
cout << endl;
}
}
int main()
{
thread t_input(input_thread);
thread t_output_even(output_even_thread);
thread t_output_odd(output_odd_thread);
t_input.join();
t_output_even.join();
t_output_odd.join();
return 0;
}
```
这里有三个线程,一个输入线程和两个输出线程,它们都共享两个计数器 `count_even` 和 `count_odd`。输入线程获取一个数字后,如果是偶数,就将 `count_even` 加 1,如果已经有 3 个偶数了,就唤醒等待偶数的输出线程;如果是奇数,则将 `count_odd` 加 1,如果已经有 3 个奇数了,就唤醒等待奇数的输出线程。
输出线程会等待条件变量 `cv`,并在满足条件时输出 3 个数字,然后继续等待下一轮。注意要在输出后将计数器清零,否则会一直等待。互斥锁 `mtx` 用于保护共享变量的访问,避免并发访问导致数据不一致。
阅读全文