二进制中1的个数-java

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

目录

前言

一、二进制中1的个数

二、算法思路

1.将一个整数转化成二进制形式

2.查询一个数的二进制数中的第k位是多少

3.lowbit(x)操作

三、代码如下

1.代码如下:

2.读入数据

3.代码运行结果

4.样例解释

总结


前言

主要通过位运算来完成两个基本操作,查询一个数的二进制数第k位数是什么,和lowbit操作返回一个二进制数中最右边的1所对应的数值,可以用来统计二进制中1的个数。

一、二进制中1的个数

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

输入格式

第一行包含整数 n。

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

输出格式

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

数据范围

1≤n≤100000
0≤数列中元素的值≤1000000000

二、算法思路

1.将一个整数转化成二进制形式

图1.1示例图 

将一个十进制数转换为二进制字符串,可以采用“除2取余数”的方法。具体步骤如下:

(1)将数字除以2。

(2)获取下一次迭代的整数商。

(3)获取其余的二进制数字。

(4)重复这些步骤,直到商等于0。

(5)将得到的所有余数全部排列起来,再将它反过来(逆序排列)。

上述图1.1中15的二进制数就是1111。

2.查询一个数的二进制数中的第k位是多少

图2.1示例图 

我们需要查看哪一位二进制数,只需要这个数右移多少位然后再与1做与运算即可。查看第1位就是这个数右移0位再与1做与运算;第2位是右移1位再与1做与运算后续以此类推。

         int x = 10;for(int i = 3;i >= 0;i--){pw.printf("%d",x >> i & 1);}运行结果: 1010

3.lowbit(x)操作

lowbit(x)函数的作用就是一个二进制数中最右边的1所对应的数值。

例如: x = 1010      lowbit(x) = _2{(10)} ,返回值是int对应的十进制是2;

x = 10010000  lowbit(x) = _2{(10000)},返回值是对应的十进制是16。

图3.1与运算模拟 

在计算机中我们常用补码来表示数据,其中第一位是符号位1表示正数,0表示负数。正数的原码、反码、补码全部相同;负数的反码是原码除了符号位全取反,补码是反码加1;从上述图3.1的过程中我们可以知道任意x和-x的补码对应的关系是-x的补码是x的补码连带符号位取反加1,最后二进制数中的最后一位1的后面x和-x相等,在二进制数中的最后一位1前面x和-x互相取反。

那么,进行与运算后二进制数中的最后一位1前面全部变成0,二进制数中的最后一位1后面的不变,此时就是二进制数中x的最后一位1和后面的二进制数。

 注:(与运算 1 & 0 = 0  、0 &1 = 0、1 & 1 = 1 、 0 & 0 = 0)

    //lowbit操作返回一个二进制数中最右边的1所对应的数值public static int lowbit(int x){return x & -x;}

三、代码如下

1.代码如下:


import java.io.*;
public class 位运算 {static PrintWriter pw = new PrintWriter(new OutputStreamWriter(System.out));static BufferedReader br = new BufferedReader(new InputStreamReader(System.in));static StreamTokenizer st = new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in)));public static void main(String[] args) throws Exception{int n = nextInt();while(n-- > 0){int x = nextInt();int res = 0;while(x != 0){//每一次减去x里面的最后一位1对应的数值,减了多少次就有多少个1x -= lowbit(x);res++;}pw.print(res+" ");}pw.flush();}public static int lowbit(int x){return x & -x;}public static String next()throws Exception{return br.readLine();}public static int nextInt()throws Exception{st.nextToken();return (int)st.nval;}
}

2.读入数据

5
1 2 3 4 5

3.代码运行结果

1 1 2 1 2 

4.样例解释

1对应的二进制为1,1的个数是1。

 2对应的二进制为10,1的个数为1。

3对应的二进制为11,1的个数为2。

4对应的二进制为100,1的个数为1。

5对应的二进制为101,1的个数为2。


总结

主要通过位运算来完成两个基本操作,查询一个数的二进制数第k位数是什么,和lowbit操作返回一个二进制数中最右边的1所对应的数值,可以用来统计二进制中1的个数。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/24818.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ChatTTS 文字生成语言本地模型部署

ChatTTS部署 官方信息 [ChatTTS首页](https://chattts.com/)搭建步骤 1、下载源码 git clone https://github.com/2noise/ChatTTS.git 2、按照环境 pip install torch ChatTTS pip install -r requirements.txt 3、下载模型 git clone https://www.modelscope.cn/pzc163/ch…

[Vue3:axios]:实现实现登陆页面前后端请求,并用Vite解决跨域问题

文章目录 一:前置依赖查看依赖安装 axios:npm install axios 二:配置文件:创建一个用于全局使用的axios实例,并在main.js或main.ts文件中将其配置为全局属性。根目录mainjs文件引入axios 三:登录页面发送登…

Polar Web【中等】xxe

Polar Web【中等】xxe Contents Polar Web【中等】xxe思路&探索EXP运行&总结 思路&探索 如题目所示,此题考查XXE漏洞,具体细节需要逐步深挖 打开站点,提示了flag所在的文件,点击按钮,可见php的配置信息&am…

一款免费文件夹同步工具,旨在帮助用户在不同磁盘或文件夹间进行文件和目录的复制、移动和同步工作

一、简介 1、一款免费文件夹同步工具,旨在帮助用户在不同磁盘或文件夹间进行文件和目录的复制、移动和同步工作。这款工具因其简单易用、高度可定制化的特点,受到了广大用户的青睐。SyncToy支持多种同步模式,包括镜像同步、单向同步以及增量同…

Mysql使用中的性能优化——索引数对INSERT性能的影响

表的索引可以给数据检索提升效率,但是也给表的增删改操作带来代价。本文我们将关注,索引数量对INSERT操作的影响。 结论 索引数的新增会造成INSERT操作效率下降,约每增一个索引会降低10%效率。 实验数据 可以看到0个索引的效率是7个索引效…

Java Web学习笔记21——前后端分离开发

前后端混合开发: 沟通成本比较高。 分工不明确。 不便管理,不便于后期的维护和拓展。 前后端分离开发: 当前主流的开发模式:前后端分离开发: 接口文档: 接口并不是interface。 接口指的是业务功能。 …

Wireshark自定义Lua插件

背景: 常见的抓包工具有tcpdump和wireshark,二者可基于网卡进行抓包:tcpdump用于Linux环境抓包,而wireshark用于windows环境。抓包后需借助包分析工具对数据进行解析,将不可读的二进制数转换为可读的数据结构。 wires…

element-plus的el-text组件(文本组件)的介绍和使用

el-text(适合文本操作的组件) 设置文本type,如default,primary,success,info,warning,danger超出容器尺寸自动省略,tuncated属性设置size属性控制文本大小,有large,default,small设置tag属性,值为html5标签名&#xf…

Nagios的安装和使用

*实验* *nagios安装和使用* Nagios 是一个监视系统运行状态和网络信息的监视系统。Nagios 能监视所指定的本地或远程主机以及服务,同时提供异常通知功能等. Nagios 可运行在 Linux/Unix 平台之上,同时提供一个可选的基于浏览器的 WEB 界面以方便系统管…

【创作活动】面对层出不穷的AI大模型产品我们应该怎么选择?

😄 19年之后由于某些原因断更了三年,23年重新扬帆起航,推出更多优质博文,希望大家多多支持~ 🌷 古之立大事者,不惟有超世之才,亦必有坚忍不拔之志 🎐 个人CSND主页——Mi…

Vue CLI 4与项目构建实战指南

title: Vue CLI 4与项目构建实战指南 date: 2024/6/9 updated: 2024/6/9 excerpt: 这篇文章介绍了如何使用Vue CLI优化项目构建配置,提高开发效率,涉及配置管理、项目部署策略、插件系统定制以及Webpack和TypeScript的深度集成技巧。 categories: 前端…

五、身份与访问管理—身份管理和访问控制管理(CISSP)

目录 1.身份管理 1.1 目录技术 1.2 单点登录 1.2.1 Kerberos认证 1.2.2 SESAME认证 1.2.3 KryptoKnight认证 1.3 联合身份管理 1.3.1 SAML安全断言标记语言 1.3.2 标记语言 1.3.3 OpenID 1.3.4 OAuth 1.3.5 OIDC(OpenID Connect) 2.身份即服务(IDaaS) 2.1 AA…

Rocky linux 搭建DNS主从服务器+keepalived实现高可用

接上两篇文章,这篇文章跟上两篇没有直接关系。 第一篇:linux rocky 搭建DNS服务和禁止AD域控DNS,做到独立DNS并加域_linux 域控-CSDN博客文章浏览阅读519次,点赞20次,收藏10次。使用linux rocky 搭建DNS服务&#xff…

【个人博客搭建】(22)申请QQ开发者

这里我们要引入的一个概念是OAuth - OAuth 2.0是一个行业标准的授权协议,用于处理用户数据访问和分享的安全问题。它允许用户将他们对某些服务的访问权限授权给第三方应用,而无需分享他们的用户名和密码。以下是对OAuth 2.0的介绍: 基本概念 …

Nvidia/算能 +FPGA+AI大算力边缘计算盒子:中国舰船研究院

中国舰船研究院又称中国船舶重工集团公司第七研究院,隶属于中国船舶重工集团公司,是专门从事舰船研究、设计、开发的科学技术研究机构,是中国船舶重工集团公司的军品技术研究中心、科技开发中心;主要从事舰船武器装备发展战略研究…

PDF编辑与转换的终极工具智能PDF处理Acrobat Pro DC

Acrobat Pro DC 2023是一款功能全面的PDF编辑管理软件,支持创建、编辑、转换、签署和共享PDF文件。它具备OCR技术,可将扫描文档转换为可编辑文本,同时提供智能PDF处理技术,确保文件完整性和可读性。此外,软件还支持电子…

竞拍商城系统源码后端PHP+前端UNIAPP

下载地址:竞拍商城系统源码后端PHP前端UNIAPP

手把手教你入门vue+springboot开发(二)

文章目录 前言一、开发环境搭建二、创建项目三、编写代码1.插件下载2.编写代码 四、测试验证总结 前言 前面我们构建了一个查询用户信息的简单springboot后端demo,今天我们先搭建VSCodevue的开发环境,然后在这个开发环境上构建一个demo,连接…

肠道病原体感染定植的三个关键角色——炎症、营养与共生菌群

谷禾健康 日常生活中大部分人都可能碰到过食用了不卫生或过期变质食物以及水源后,出现过恶心、腹痛,并伴有腹泻、食欲不振、呕吐等症状?如果有就要当心,这可能是病原体感染引起的胃肠道炎症。 但是,即使食用了同样食物…

mysql中 redo日志(下)

大家好。上篇文章我们介绍了什么是redo日志以及redo日志的写入过程。建议没看过上篇文章的同学先看一下上一篇文章,今天我们继续来说一说redo日志。 一、redo日志文件 1. redo日志刷盘时机 我们知道mtr运行过程中产生的一组redo日志在mtr结束时会被复制到log buf…