题解 | #四选一多路器#

四选一多路器

https://www.nowcoder.com/practice/cba4617e1ef64e9ea52cbb400a0725a3

`timescale 1ns/1ns
module mux4_1(
input [1:0]d1,d2,d3,d0,
input [1:0]sel,
output[1:0]mux_out
);
//*************code***********//
wire [1:0]line1,line2;
assign line1=(sel[0])?d2:d3;
assign line2=(sel[0])?d0:d1;
assign mux_out=(sel[1])?line2:line1;
//*************code***********//
endmodule

题目规定输出类型为wire。

方法一:不使用always,只使用assign。

由三个二选一数据选择器构成四选一数据选择器。

d0 11

d1 10

d2 01

d3 00

分两组,以sel(0)作为第一级两个mux2_1的数据选择端,以sel(1)作为第二级一个mux2_1的数据选择端。

因此高位相同全为1的d0,d1为一组,d2,d3为一组。

方法二:中间变量为reg,使用always+case,最后在用assign赋给输出。

全部评论

相关推荐

程序员小白条:这比例牛逼,750:1
点赞 评论 收藏
分享
06-26 22:20
门头沟学院 Java
码农索隆:让你把简历发给她,她说一些套话,然后让你加一个人,说这个人给你改简历,然后开始卖课
我的求职精神状态
点赞 评论 收藏
分享
最近拿到了正浩的提前批offer感觉自己的实力得到了肯定,也给了我更多底气
搞机墨镜猫:正浩提前批官网好像就只有电力电子软硬件,哥们投的是这两个岗位吗
26届校招投递进展
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务