JAVA的BIT数组
写个小东西,要去重复数字,用到BIT数组,虽然JAVA已经提供了一个BitSet,不过自己手痒,又写了一个简单的
原理就不写了,网上一大堆
import java.util.Iterator;
import java.util.function.BiConsumer; public class BitArray implements Iterable<Boolean>{
//表示1<<n的值,提高效率,不用每次计算
private final byte[] MASK = new byte[]{1,2,4,8,16,32,64,(byte)128};
byte[] bits;
int max = 0; /**
* 构造一个Bit数组
* @param max 最大位数
*/
public BitArray(int max){
this.max = max;
int len = max / 8 + 1; bits = new byte[len];
} /**
* 设置第N位的值
* @param index Bit索引
* @param value 值
*/
public void set(int index,boolean value){
int i = index / 8;
int move = index % 8; bits[i] = (byte)(bits[i] | MASK[move]);
} /**
* 取得第N位的值
* @param index Bit索引
* @return
*/
public boolean get(int index){
int i = index / 8;
int move = index % 8; return (bits[i] & MASK[move]) == MASK[move];
} /**
* 显示所有位
*/
public void show(){
for(int i=0; i<bits.length; i++){
byte b = bits[i];
for(int bitIndex=0; bitIndex<8;bitIndex++){
System.out.print( ((b>>bitIndex) & 1) + " ");
}
System.out.println();
}
} /**
* 提供遍历接口
*/
public Iterator<Boolean> iterator() {
return new Iterator<Boolean>(){
private int i = 0; public boolean hasNext() {
return i <= max;
} public Boolean next() {
return get(i++);
} };
} /**
* 遍历,偷懒用了JAVA8的新接口
* @param fun
*/
public void forEach(BiConsumer<Integer,Boolean> fun){
int total = 0;
for(int i=0; i<bits.length; i++){
byte b = bits[i];
for(int bitIndex=0; bitIndex<8 && total<=max;bitIndex++,total++){
fun.accept(total, ((b>>bitIndex) & 1) == 1);
}
}
}
}
使用方式:
public static void main( String[] args ) throws Exception
{
BitArray bits = new BitArray(18);
bits.set(18,true);
System.out.println("position 3 : " + bits.get(3));
System.out.println("position 18 : " + bits.get(18));
System.out.println("--------------------------"); //遍历方式 一
int i = 0;
for(Boolean result : bits)
System.out.println(i++ + " : " + result); System.out.println("--------------------------"); //遍历方式二
BiConsumer<Integer,Boolean> fun = (index, value)->{
System.out.println(index + " : " + value);
};
bits.forEach(fun);
}
输出结果:
/*
position 3 : false
position 18 : true
--------------------------
0 : false
1 : false
2 : false
3 : false
4 : false
5 : false
6 : false
7 : false
8 : false
9 : false
10 : false
11 : false
12 : false
13 : false
14 : false
15 : false
16 : false
17 : false
18 : true
--------------------------
0 : false
1 : false
2 : false
3 : false
4 : false
5 : false
6 : false
7 : false
8 : false
9 : false
10 : false
11 : false
12 : false
13 : false
14 : false
15 : false
16 : false
17 : false
18 : true
*/
JAVA的BIT数组的更多相关文章
- Java反射遍历数组
日志中有时候需要查看数组中的值,但是重载很多的打印函数,觉得很别扭.所以想通过反射,获取数组中的值,打印出来.Java提供了数组反射操作的类,之前没有关注过,提供的方法简单易用. public sta ...
- 慕课网-安卓工程师初养成-6-3 如何使用 Java 中的数组
来源:http://www.imooc.com/code/1525 Java 中操作数组只需要四个步骤: 1. 声明数组 语法: 或者 其中,数组名可以是任意合法的变量名,如: 2. 分配空间 简 ...
- Java中的数组操作进阶
package com.mi.array; import java.util.Arrays; /** * System.arraycopy(i, 0, j, 0, i.length);这种复制会覆盖目 ...
- 如何使用 Java 中的数组
Java 中操作数组只需要四个步骤: 1. 声明数组 语法: 数据类型[ ] 数组名: 或者 数据类型 数组名[ ]: 其中,数组名可以是任意合法的变量名,如: 2. 分配空间 简单地说,就是指 ...
- Java之组合数组1
我们先说"数组",数组是有序数据的集合,数组中的每个元素具有相同的数组名和下标来唯一地确定数组中的元素. 一.一维数组的定义 type arrayName[]; 其中类型(type ...
- Java比较器对数组,集合排序一
数组排序非常简单,有前辈们的各种排序算法,再加上Java中强大的数组辅助类Arrays与集合辅助类Collections,使得排序变得非常简单,如果说结合比较器Comparator接口和Collato ...
- 【转】java中byte数组与int类型的转换(两种方式)----不错
原文网址:http://blog.csdn.net/piaojun_pj/article/details/5903009 java中byte数组与int类型的转换,在网络编程中这个算法是最基本的算法, ...
- java随机数与数组的使用。
java随机数与数组的使用. 一:题目 二 代码: public class Students { int number; // 学号 int State ; // 年级 ...
- Java的byte数组
今天我们讨论一下Java的byte数组.byte数组就是字节数组,每一位存一个字节.看下面程序,猜猜输出多少? package com.wjy.bytes; import java.io.File; ...
- Java 泛型 泛型数组
Java 泛型 泛型数组 @author ixenos 先给结论 不能(直接)创建泛型数组 泛型数组实际的运行时对象数组只能是原始类型( T[]为Object[],Pair<T>[]为Pa ...
随机推荐
- HDU 2685 I won't tell you this is about number theory
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2685 题意:求gcd(a^m - 1, a^n - 1) mod k 思路:gcd(a^m - 1, ...
- Java并发编程实践(读书笔记) 任务执行(未完)
任务的定义 大多数并发程序都是围绕任务进行管理的.任务就是抽象和离散的工作单元. 任务的执行策略 1.顺序的执行任务 这种策略的特点是一般只有按顺序处理到来的任务.一次只能处理一个任务,后来其它任 ...
- Docker基本概念填坑
Docker的基本概念填坑 Docker的基本概念填坑 1. Docker的基本组成 Docker Client客户端 Docker Daemon守护进程 Docker Image镜像 Docker ...
- org.gradle.process.internal.ExecException:
com.android.ide.common.process.ProcessException: org.gradle.process.internal.ExecException: Process ...
- SilverLight搭建WCF聊天室详细过程
收藏SL双工通信例子教程 SilverLight 4正式版发布给开发人员带来了更多功能,并且4已经支持NET.TCP协议,配合WCF开发高效率的交互应用程序已经不再是难事,本系列文章主要针对已经完成的 ...
- Cocos2d-x 安装教程for mac(Xcode)
cocos2d v3.x 版本出来后,从配置安装到创建项目都是命令行,下面简单说一下. 1. 下载地址 http://cn.cocos2d-x.org/download/ (虽然没有标明 for ...
- MySQLdb callproc 方法
MySQLdb执行存储过程时就要调用 callproc 方法.它返回的是调用时的参数列表. MySQL 中存储过程的定如下: delimiter // create procedure proc_in ...
- 限制ITEM读取其它物料的物料描述
应用 Oracle Purchasing 层 Level Function 函数名 Funcgtion Name CUXPOXPOEPO 表单名 Form Name POXPOEPO 说明 Des ...
- “_In_opt_z_”: 未声明的标识符
问题 使用VS2010 + WDK 环境进行驱动开发时,编译阶段出现如下等错误提示 “_In_opt_z_”: 未声明的标识符 解决办法 将..\Microsoft Visual Studio 10. ...
- SQLServer2012 和 MariaDB 10.0.3 分页效率的对比
1. 实验环境 R910服务器, 16G内存 SqlServer 2012 64bit MariaDB 10.0.3 64bit (InnoDB) 2. 实验表情况 rtlBill ...