Java程序检查两个数字的二进制表示形式是否为字谜
如果两个数字的二进制表示形式具有相同的0'a和1's,则它们是anagram。一个例子如下:
Number 1 = 3 Binary representation of Number 1 = 0011 Number 2 = 12 Binary representation of Number 2 = 1100
这两个数字是字谜。
演示此的程序如下所示-
示例
public class Example {
public static void main (String[] args) {
long x = 12, y = 3;
if(Long.bitCount(x) == Long.bitCount(y))
System.out.println("Binary representations of " + x + " and " + y + " are anagrams");
else
System.out.println("Binary representations of " + x + " and " + y + " are not anagrams");
}
}上面程序的输出如下-
Binary representations of 12 and 3 are anagrams
现在让我们了解上面的程序。
定义了x和y的值。然后,对位表示中的1进行计数。如果它们相等,则x和y的二进制表示形式是字谜,否则不是。证明这一点的代码片段如下所示-
long x = 12, y = 3;
if(Long.bitCount(x) == Long.bitCount(y))
System.out.println("Binary representations of " + x + " and " + y + " are anagrams");
else
System.out.println("Binary representations of " + x + " and " + y + " are not anagrams");热门推荐
10 对患者生日祝福语简短
11 结婚祝福语简短装备
12 周岁祝福语学生文案简短
13 订婚领证祝福语简短精辟
14 导师获奖祝福语大全简短
15 新婚购房祝福语简短精辟
16 牛年祝福语简短的爱人
17 送芒果的祝福语简短
18 送给学长毕业祝福语简短