热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

检查一个数字是否有相同数量的置位和未置位位

检查一个数字是否有相同数量的置位和未置位位原文:https://

检查一个数字是否有相同数量的置位和未置位位

原文:https://www . geesforgeks . org/check-if-a-number-with-number-of-set-and-unset-bits/

给定一个数字 N,任务是检查给定数字中的设置位和未设置位的计数是否相同。
例:

Input: 12
Output: Yes
1100 is the binary representation of 12
which has 2 set and 2 unset bits
Input: 14
Output: No

方法:在给定数字的二进制表示中遍历,使用 n & 1 检查最左边的位是否被设置。如果 n & 1 返回 1,则最左边的位被置位。对,每次将数字移动 1 来检查下一位。一旦二进制表示被完全遍历,检查设置位和未设置位的数量是否相同。如果相同,则打印“是”,否则打印“否”。
以下是上述方法的实施:

C++


// C++ program to check if a number
// has same number of set and unset bits
#include
using namespace std;
// Function to check if a number
// has same setbits and unset bits
bool checkSame(int n)
{
    int set = 0, unset = 0;
    // iterate for all bits of a number
    while (n) {
        // if set
        if (n & 1)
            set++;
        // if unset
        else
            unset++;
        // right shift number by 1
        n = n >> 1;
    }
    // is number of set bits are
    // equal to unset bits
    if (set == unset)
        return true;
    else
        return false;
}
// Driver Code
int main()
{
    int n = 12;
    // function to check
    if (checkSame(n))
        cout << "YES";
    else
        cout << "NO";
    return 0;
}


Java 语言(一种计算机语言,尤用于创建网站)


// Java program to check if
// a number has same number
// of set and unset bits
import java.io.*;
class GFG
{
// Function to check if a
// number has same setbits
// and unset bits
static boolean checkSame(int n)
{
    int set = 0;
    int unset = 0;
    // iterate for all
    // bits of a number
    while (n > 0)
    {
        // if set
        if ((n & 1) ==  1)
            set++;
        // if unset
        else
            unset++;
        // right shift
        // number by 1
        n = n >> 1;
    }
    // is number of set bits
    // are equal to unset bits
    if (set == unset)
        return true;
    else
        return false;
}
// Driver Code
public static void main (String[] args)
{
int n = 12;
// function to check
if (checkSame(n))
    System.out.println ("YES");
else
    System.out.println("NO");
}
}
// This code is contributed
// by akt_mit


Python 3


# Python program to check if a number
# has same number of set and unset bits
# Function to check if a number
# has same setbits and unset bits
def checkSame(n):
    set, unset = 0, 0
    # iterate for all bits of a number
    while(n):
        # if set
        if (n and 1):
            set + 1
        # if unset
        else:
            unset += 1
        # right shift number by 1
        n = n >> 1
    # is number of set bits are
    # equal to unset bits
    if (set == unset):
        return True
    else:
        return False
# Driver Code
if __name__ == '__main__':
    n = 12
    # function to check
    if (checkSame(n)):
        print("YES")
    else:
        print("NO")
# This code is contributed
# by 29AjayKumar


C


// C# program to check if
// a number has same number
// of set and unset bits
using System;
public class GFG{
// Function to check if a
// number has same setbits
// and unset bits
static bool checkSame(int n)
{
    int set = 0;
    int unset = 0;
    // iterate for all
    // bits of a number
    while (n > 0)
    {
        // if set
        if ((n & 1) == 1)
            set++;
        // if unset
        else
            unset++;
        // right shift
        // number by 1
        n = n >> 1;
    }
    // is number of set bits
    // are equal to unset bits
    if (set == unset)
        return true;
    else
        return false;
}
// Driver Code
    static public void Main (){
        int n = 12;
    // function to check
    if (checkSame(n))
        Console.WriteLine("YES");
    else
        Console.WriteLine("NO");
    }
}


服务器端编程语言(Professional Hypertext Preprocessor 的缩写)



// PHP program to check if a number
// has same number of set and unset bits
// Function to check if a number
// has same setbits and unset bits
function checkSame($n)
{
    $set = 0;
    $unset = 0;
    // iterate for all bits
    // of a number
    while ($n)
    {
        // if set
        if ($n & 1)
            $set++;
        // if unset
        else
            $unset++;
        // right shift number by 1
        $n = $n >> 1;
    }
    // is number of set bits are
    // equal to unset bits
    if ($set == $unset)
        return true;
    else
        return false;
}
// Driver Code
$n = 12;
// function to check
if (checkSame($n))
    echo "YES";
else
    echo "NO";
// This code is contributed
// by Sach_Code
?>


java 描述语言



Output: 

YES


推荐阅读
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • 猜字母游戏
    猜字母游戏猜字母游戏——设计数据结构猜字母游戏——设计程序结构猜字母游戏——实现字母生成方法猜字母游戏——实现字母检测方法猜字母游戏——实现主方法1猜字母游戏——设计数据结构1.1 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • Ihavethefollowingonhtml我在html上有以下内容<html><head><scriptsrc..3003_Tes ... [详细]
  • 先看官方文档TheJavaTutorialshavebeenwrittenforJDK8.Examplesandpracticesdescribedinthispagedontta ... [详细]
  • 学习Java异常处理之throws之抛出并捕获异常(9)
    任务描述本关任务:在main方法之外创建任意一个方法接收给定的两个字符串,把第二个字符串的长度减1生成一个整数值,输出第一个字符串长度是 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • 阿,里,云,物,联网,net,core,客户端,czgl,aliiotclient, ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • C# 7.0 新特性:基于Tuple的“多”返回值方法
    本文介绍了C# 7.0中基于Tuple的“多”返回值方法的使用。通过对C# 6.0及更早版本的做法进行回顾,提出了问题:如何使一个方法可返回多个返回值。然后详细介绍了C# 7.0中使用Tuple的写法,并给出了示例代码。最后,总结了该新特性的优点。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • 开发笔记:Java是如何读取和写入浏览器Cookies的
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了Java是如何读取和写入浏览器Cookies的相关的知识,希望对你有一定的参考价值。首先我 ... [详细]
  • 本文记录了在vue cli 3.x中移除console的一些采坑经验,通过使用uglifyjs-webpack-plugin插件,在vue.config.js中进行相关配置,包括设置minimizer、UglifyJsPlugin和compress等参数,最终成功移除了console。同时,还包括了一些可能出现的报错情况和解决方法。 ... [详细]
  • 本文介绍了Swing组件的用法,重点讲解了图标接口的定义和创建方法。图标接口用来将图标与各种组件相关联,可以是简单的绘画或使用磁盘上的GIF格式图像。文章详细介绍了图标接口的属性和绘制方法,并给出了一个菱形图标的实现示例。该示例可以配置图标的尺寸、颜色和填充状态。 ... [详细]
author-avatar
CPA娇_588
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有