Verilog中,判断两个数是不是相等,一个数16位,一个数17位,16位的能自动补0吗?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Verilog中,判断两个数是不是相等,一个数16位,一个数17位,16位的能自动补0吗?相关的知识,希望对你有一定的参考价值。

这是一个严肃的问题,请不懂Verilog的不要乱写

会的。根据Verilog语法规则,位数少的数自动在最高位补足0再进行判断,关系运算都是如此。 参考技术A Verilog HDL入门 第三版 55 页
若操作数的位宽不同,并且所有操作数都是无符号的,则位宽较小的操作数在高位(左方)添补齐。

列子: b1000>=b01110
等于 b01000>=b01110
判断结果当然为假!!!本回答被提问者采纳

如何判断两个list集合是不是相等

参考技术A 在终端上测试就可以了
A = [1,2,3,4]
B = [1,2,3,4]
A == B
以上返回结果为True,如果不相等返回Flase。
参考技术B

首先这里需要确定一下集合相等的定义,我们应该是认为两个集合的元素完全一致则相等。那么判断可以这样做:

    第一步:判断两个list集合的元素个数是否相等。如果不相等则两个list集合也不相等,判断结束,如果相等则进入第二步判断

    第二步:判断list1的元素是否全部在list2中。遍历list1,取出list1中的元素,依次去list2中比较是否list2也存在这个元素。如果有任何一个list1中的元素在list2中不存在,则两个list集合不相等,如果全部存在则两个list集合相等。

    第三步:判断list2的元素是否全部在list1中。判断方式同上。如果能确保list1和list2内的元素都不重复那么第三步可以省略。

以下是上诉过程的Java代码例子:

public boolean equalList(List list1, List list2)

if (list1.size() != list2.size())

return false;

for (Object object : list1)

if (!list2.contains(object))

return false;


for (Object object : list2)

if (!list1.contains(object))

return false;

return true;


以上过程适用于所有编程语言。另外不同编程语言还提供了一些其他方法,所以对于不同编程语言还可以有其他写法。

比如Java中为list集合提供了containsAll方法。所以对于Java语言还可以这么写:

public boolean equalList(List list1, List list2)

if (list1.size() != list2.size())

return false;

if (list2.containsAll(list1) && list1.containsAll(list2))

return true;

return false;

还可以简写成这样

public boolean equalList(List list1, List list2)

return (list1.size() == list2.size()) && list1.containsAll(list2) && list2.containsAll(list1);

参考技术C

最直接的办法就是遍历两个List中的每一个元素,遇到不相等的就break,返回false。下面的代码表示的就是这样一个意思。

以上是关于Verilog中,判断两个数是不是相等,一个数16位,一个数17位,16位的能自动补0吗?的主要内容,如果未能解决你的问题,请参考以下文章

检测数组里是不是有两个数之和等于某个数

如何用C语言判断一个数是不是为递增数

判断两个数组是不是相等

java怎么比较两个list是不是相同?

java 怎么比较两个list是不是相同

java怎么比较两个list是不是相同?