HDLbits刷题记录之Always case2

HDLbits刷题记录之Always case2

题目:
要求是判断4位2进制数的1的从右往左第一次出现的位置,出现在右边第一个为0,出现在右边第二个的为1,依次类推。
我第一遍就只写了in=4’b1000、4’b0100、4’b0010、4’b0001这四种情况,可想而知,1不止出现一次。因此我把其他都写出来了。代码如下:

// synthesis verilog_input_version verilog_2001
module top_module (
    input [3:0] in,
    output reg [1:0] pos  );
    always@(*)begin
        case(in)
            4'b1000 : pos = 3;
            4'b0100 : pos = 2;
            4'b1100 : pos = 2;
            4'b0010 : pos = 1;
            4'b0110 : pos = 1;
            4'b1010 : pos = 1;
            4'b1110 : pos = 1;
            4'b0001 : pos = 0;
            4'b0011 : pos = 0;
            4'b0101 : pos = 0;
            4'b0111 : pos = 0;
            4'b1001 : pos = 0;
            4'b1011 : pos = 0;
            4'b1101 : pos = 0;
            4'b1111 : pos = 0;
            default : pos = 0;
        endcase
    end
        

endmodule

总结感悟:

菜鸡本鸡。。。。。。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值