没什么了。

简介: 没什么了。

题目描述

给定一个长度为n的数列,请你求出数列中每个数的二进制表示中1的个数。

输入格式

第一行包含整数n。

第二行包含n个整数,表示整个数列。

输出格式

共一行,包含n个整数,其中的第 i 个数表示数列中的第 i 个数的二进制表示中1的个数。

数据范围

1≤n≤100000,

0≤数列中元素的值≤109

样例

输入样例:

5

1 2 3 4 5

输出样例:

1 1 2 1 2

算法1

(lowbit) O(nlogn)O(nlogn)

使用lowbit操作,进行,每次lowbit操作截取一个数字最后一个1后面的所有位,每次减去lowbit得到的数字,直到数字减到0,就得到了最终1的个数,

lowbit原理

根据计算机负数表示的特点,如一个数字原码是10001000,他的负数表示形势是补码,就是反码+1,反码是01110111,加一则是01111000,二者按位与得到了1000,就是我们想要的lowbit操作

C++ 代码

#include
using namespace std;
int lowbit(int x){
return x&(-x);
}
int main(){
int n;
cin>>n;
while(n–){
int x;
cin>>x;
int res=0;
    while(x) x-=lowbit(x),res++;
    cout<<res<<' ';
}
return 0;

}

算法2

(暴力枚举) O(nlongn)O(nlongn)

blablabla

时间复杂度分析:blablabla

思路

对于每个数字a,a&1得到了该数字的最后一位,之后将a右移一位,直到位0,就得到了1的个数

C++ 代码

#include
using namespace std;
int n;
int a,k;
int main(){
scanf(“%d”,&n);
for(int i=0;i<n;i++){
scanf(“%d”,&a);
k=0;
while(a){
k+=a&1;
a=a>>1;
}
printf("%d ",k);
}
return 0;
}

笔记:

位运算是个好东西可惜我不会用。

这个帖子适合位运算中有一定基础的童鞋们看。

大佬别来虐场

求nn的二进制位表示中第kk为是几?

把第kk位移动到最后一位。

看各位

得出公式n>>k&1

返回nn的最后一位11。

也就是求解lowbit(n)lowbit(n)。

求解过程:n&(-n)

统计nn的二进制表示中11的个数(本题)?

while(n) ans++, n -= lowbit(n);

代码:

#include <bits/stdc++.h>
using namespace std;
int lowbit(int x) {
return x & (-x);
}
int main() {
int t, x; cin>>t;
while (t–) {
cin>>x;
int ans = 0;
while (x) ans ++, x -= lowbit(x);
cout << ans << " ";
}
return 0;
}

题目描述

给定一个长度为n的数列,请你求出数列中每个数的二进制表示中1的个数。

输入格式

第一行包含整数n。

第二行包含n个整数,表示整个数列。

输出格式

共一行,包含n个整数,其中的第 i 个数表示数列中的第 i 个数的二进制表示中1的个数。

数据范围

1≤n≤100000,

0≤数列中元素的值≤109

样例

输入样例:

5

1 2 3 4 5

输出样例:

1 1 2 1 2

算法1

(lowbit) O(nlogn)O(nlogn)

使用lowbit操作,进行,每次lowbit操作截取一个数字最后一个1后面的所有位,每次减去lowbit得到的数字,直到数字减到0,就得到了最终1的个数,

lowbit原理

根据计算机负数表示的特点,如一个数字原码是10001000,他的负数表示形势是补码,就是反码+1,反码是01110111,加一则是01111000,二者按位与得到了1000,就是我们想要的lowbit操作

C++ 代码

#include
using namespace std;
int lowbit(int x){
return x&(-x);
}
int main(){
int n;
cin>>n;
while(n–){
int x;
cin>>x;
int res=0;
    while(x) x-=lowbit(x),res++;
    cout<<res<<' ';
}
return 0;

}

算法2

(暴力枚举) O(nlongn)O(nlongn)

blablabla

时间复杂度分析:blablabla

思路

对于每个数字a,a&1得到了该数字的最后一位,之后将a右移一位,直到位0,就得到了1的个数

C++ 代码

#include
using namespace std;
int n;
int a,k;
int main(){
scanf(“%d”,&n);
for(int i=0;i<n;i++){
scanf(“%d”,&a);
k=0;
while(a){
k+=a&1;
a=a>>1;
}
printf("%d ",k);
}
return 0;
}


相关文章
|
3月前
|
人工智能 小程序 算法
分享64个JavaGame源码总有一个是你想要的
分享64个JavaGame源码总有一个是你想要的
43 0
|
3月前
|
人工智能 Java 关系型数据库
分享66个JavaGame源码总有一个是你想要的
分享66个JavaGame源码总有一个是你想要的
62 0
|
8月前
不是工作不好找,是你真的不行
不是工作不好找,是你真的不行
|
算法 C++
没什么。。。。
没什么。。。。
|
编解码 前端开发 程序员
为啥只跟着视频敲代码学不好编程?
为啥只跟着视频敲代码学不好编程?
304 1
|
存储 Java
来自三段代码的疑惑~
来自三段代码的疑惑~
88 0
|
移动开发 缓存 ARouter
没错,TheRouter 是我写的
大约在17年底到18年初的时候,我经常会讲一些当时做模块化开发的心得和踩坑历程
168 0
|
Web App开发 Ubuntu JavaScript
我好像明白了什么.....
谷歌浏览器是最流行的网络浏览器,无论你是否喜欢使用它,Chrome都毋庸置疑提供良好的用户体验。 尽管它可用于Linux,但它并不是一个开源的网络浏览器。
我好像明白了什么.....
|
算法 Java
别在网上乱找代码了,找了一段代码突然爆了!!!
本人是做游戏服务器开发的,碰到一个需求,给符某些要求的玩家的发送道具奖励,奖励的数量根据离线的天数计算。 这个需求实现起来很简单,只需要在玩家上线的时候计算上次离线时间和当前时间间隔的天数,然后根据策划的算法,计算出道具种类与数量,发一封邮件给玩家就可以了。

热门文章

最新文章