题解 | #状态机-非重叠的序列检测#

状态机-非重叠的序列检测

https://www.nowcoder.com/practice/2e35c5c0798249aaa2e1044dbaf218f2

`timescale 1ns/1ns

module sequence_test1(
	input wire clk  ,
	input wire rst  ,
	input wire data ,
	output reg flag
);
//*************code***********//
parameter	s0	=	5'b00001,
			s1  =	5'b00010,
			s2	= 	5'b00100,
			s3	=	5'b01000,
			s4	=	5'b10000;
reg	[4:0]	cur_state,nxt_state;
reg	data_reg;
always@(posedge clk or negedge rst)
	if(!rst)
		data_reg	<=	1'b0;
	else	
		data_reg	<=	data;

always@(posedge clk or negedge rst)
	if(!rst)
		cur_state	<=	s0;
	else	
		cur_state	<=	nxt_state;

always@(*)
	if(!rst)
		nxt_state	<=	s0;
	else	case(cur_state)
	s0:begin
		nxt_state	<=	(data_reg)	? s1:s0;
	end
	s1:begin
		nxt_state	<=	(data_reg)	? s0:s2;
	end
	s2:begin
		nxt_state	<=	(data_reg)	? s3:s0;
	end
	s3:begin
		nxt_state	<=	(data_reg)	? s4:s2;
	end
	s4:begin
		nxt_state	<=	(data_reg)	? s0:s2;
	end
		default:	nxt_state	<=	s0;

	endcase


always@(*)
	if(!rst)
		flag	<=	1'b0;
	else	if(cur_state==s4 && data_reg)
		flag	<=	1'b1;
	else
		flag	<=	1'b0;

//*************code***********//
endmodule

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-16 14:00
白火同学:其实你可以了解一下HR在Boss聊天的机制,想赢牌的前提是先会玩牌。 如果HR长时间没有理你,有可能是因为你的消息被其他应聘者的消息给挤到下面了,HR从上到下有可能只看个三四百个人就要到理想数量的简历了,而你恰好没有被看到,时间一长,你的消息在越来越下面。这种情况就需要你自己活跃一下,把消息提上去。 也可能是HR招的合适的人选了,但会一直挂着岗位,为了省重新开招聘岗位的钱,方便后面随时修改招聘要求。 当然也可能是HR吃饱了没事耍你玩,要了你的简历又不看,就看你自己怎么理解了。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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