首页 > Windows开发 > 详细

位运算(AcWing.800)

时间:2020-02-23 09:35:49      阅读:71      评论:0      收藏:0      [点我收藏+]

首先先讲位运算两个比较重要的知识点

求n的第K位数字:n>>k&1

返回n的最后一位1 :lowbit(n)=n&-n;

#include<iostream>
using namespace std;
int n;
const int N = 100010;
int a[N];
int lowbit(int n)
{
    return n&-n;
}
int main()
{
    cin>>n;
    for(int i=0;i<n;i++)
    {
        int res=0;
        cin>>a[i];
        while(a[i]){a[i]-=lowbit(a[i]); res++ ;}//根据前面的知识点这部操作就可完成上述操作。
        cout<<res<< ;
    }
}

 

位运算(AcWing.800)

原文:https://www.cnblogs.com/zyz010206/p/12348315.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!