题解 | #自动售卖机#

自动售卖机

https://www.nowcoder.com/practice/487953e6d3e3434988e0dd6960b6c9f8

`timescale 1ns/1ns

module sale(
   input                clk   ,
   input                rst_n ,
   input                sel   ,//sel=0,5$dranks,sel=1,10&=$drinks
   input          [1:0] din   ,//din=1,input 5$,din=2,input 10$
 
   output   reg  [1:0] drinks_out,//drinks_out=1,output 5$ drinks,drinks_out=2,output 10$ drinks
   output	reg        change_out   
);

reg save_five; //题目未说可以存钱 =1 存5块钱
always@(posedge clk or negedge rst_n)begin
    if(!rst_n)begin
        drinks_out <= 2'b0;
        change_out <= 1'b0;
        save_five <= 1'b0;
    end
    else if(sel)begin   //B饮料 10元
        if(din==2'd1)begin
            drinks_out <= 2'b0;
            change_out <= 1'b0;
            save_five <= 1'b1;
            if(save_five)begin
                drinks_out <= 2'd2;
                change_out <= 1'b0;
                save_five <= 1'b0;
            end
        end
        else if(din == 2'd2)begin
            drinks_out <= 2'd2;
            change_out <= 1'b0;
            if(save_five)begin
                drinks_out <= 2'd2;
                change_out <= 1'b1;
                save_five <= 1'b0;
            end
        end
        else begin
            drinks_out  <= 2'b0;
            change_out <= 1'b0;
        end
    end
    else begin  //A 5
        if(din == 2'd1)begin
            change_out<=1'b0;
            drinks_out <= 2'd1;
        end
        else if(din == 2'd2)begin
            change_out <= 1'b1;
            drinks_out <= 2'd1;
        end
        else begin
            change_out <= 1'b0;
            drinks_out <= 2'b0;
        end
    end
end
endmodule

全部评论

相关推荐

接好运Plus:定时器项目都被用烂了,感觉
点赞 评论 收藏
分享
10-28 10:48
已编辑
门头沟学院 Java
孩子我想要offer:发笔试后还没笔试把我挂了,然后邮箱一直让我测评没测,后面不知道干嘛又给我捞起来下轮笔试,做完测评笔试又挂了😅
点赞 评论 收藏
分享
评论
6
收藏
分享

创作者周榜

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