题解 | #不重叠序列检测#

不重叠序列检测

https://www.nowcoder.com/practice/9f91a38c74164f8dbdc5f953edcc49cc

`timescale 1ns/1ns
module sequence_detect(
	input clk,
	input rst_n,
	input data,

	output reg match,
	output reg not_match
);

reg [2:0]cnt;
always@(posedge clk or negedge rst_n)
	if (rst_n == 1'b0)
		cnt <= 3'b0;
	else if (cnt == 3'd5)
		cnt <= 3'b0;
	else
		cnt <= cnt + 1'b1;

reg [5:0]data_reg;
always@(posedge clk or negedge rst_n)
	case(cnt)
		3'd0 : data_reg[0] <= data;
		3'd1 : data_reg[1] <= data;
		3'd2 : data_reg[2] <= data;
		3'd3 : data_reg[3] <= data;
		3'd4 : data_reg[4] <= data;
		3'd5 : data_reg[5] <= data;
		default : data_reg <= 6'b0;
	endcase

always@(posedge clk or negedge rst_n)
	if (rst_n == 1'b0)
		begin
			match <= 1'b0;
			not_match <= 1'b0;
		end
	else if (cnt == 3'd5)
		begin
			if (data_reg == 6'b00_1110)
				begin
					match <= 1'b1;
					not_match <= 1'b0;
				end
			else
				begin
					match <= 1'b0;
					not_match <= 1'b1;
				end
		end
	else
		begin
			match <= 1'b0;
			not_match <= 1'b0;
		end
			
endmodule

为什么我自测运行显示“您的程序未能在规定时间内运行结束,请检查是否循环有错或算法复杂度过大。”,但是提交后可以通过???

全部评论

相关推荐

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

创作者周榜

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