Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 328|回复: 0

[集合学习]java中的BitSet学习

[复制链接]
  • TA的每日心情
    开心
    2021-3-12 23:18
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2014-10-29 23:56:18 | 显示全部楼层 |阅读模式
    (1)BitSet类
         大小可动态改变, 取值为true或false的位集合。用于表示一组布尔标志。   

    此类实现了一个按需增长的位向量。位 set 的每个组件都有一个 boolean 值。用非负的整数将 BitSet 的位编入索引。可以对每个编入索引的位进行测试、设置或者清除。通过逻辑与、逻辑或和逻辑异或操作,可以使用一个 BitSet 修改另一个 BitSet 的内容。  默认情况下,set 中所有位的初始值都是 false。   每个位 set 都有一个当前大小,也就是该位 set 当前所用空间的位数。注意,这个大小与位 set 的实现有关,所以它可能随实现的不同而更改。位 set 的长度与位 set 的逻辑长度有关,并且是与实现无关而定义的。    除非另行说明,否则将 null 参数传递给 BitSet 中的任何方法都将导致 NullPointerException。 在没有外部同步的情况下,多个线程操作一个 BitSet 是不安全的。  
      
       
       
         
       

         
       
      
      (2) 构造函数: BitSet() or BitSet(int nbits)  (3) 一些方法
    public void set(int pos): 位置pos的字位设置为true。
    public void set(int bitIndex, boolean value) 将指定索引处的位设置为指定的值。
    public void clear(int pos): 位置pos的字位设置为false。
    public void clear() : 将此 BitSet 中的所有位设置为 false。
    public int cardinality() 返回此 BitSet 中设置为 true 的位数。
    public boolean get(int pos): 返回位置是pos的字位值。
    public void and(BitSet other): other同该字位集进行与操作,结果作为该字位集的新值。
    public void or(BitSet other): other同该字位集进行或操作,结果作为该字位集的新值。
    public void xor(BitSet other): other同该字位集进行异或操作,结果作为该字位集的新值。
    public void andNot(BitSet set) 清除此 BitSet 中所有的位,set - 用来屏蔽此 BitSet 的 BitSet
    public int size(): 返回此 BitSet 表示位值时实际使用空间的位数。
    public int length() 返回此 BitSet 的“逻辑大小”:BitSet 中最高设置位的索引加 1。
    public int hashCode(): 返回该集合Hash 码, 这个码同集合中的字位值有关。
    public boolean equals(Object other): 如果other中的字位同集合中的字位相同,返回true。
    public Object clone() 克隆此 BitSet,生成一个与之相等的新 BitSet。
    public String toString() 返回此位 set 的字符串表示形式。  例1:标明一个字符串中用了哪些字符
    1. import java.util.BitSet;
    2. public class WhichChars{
    3.    private BitSet used = new BitSet();
    4.    public WhichChars(String str){
    5.       for(int i=0;i< str.length();i++)
    6.         used.set(str.charAt(i));  // set bit for char
    7.    }
    8.     public String toString(){
    9.          String desc="[";
    10.          int size=used.size();
    11.           for(int i=0;i< size;i++){
    12.              if(used.get(i))
    13.                  desc+=(char)i;
    14.             }
    15.              return desc+"]";
    16.          }
    17.     public static void main(String args[]){
    18.         WhichChars w=new WhichChars("How do you do");
    19.         System.out.println(w);
    20.     }
    21.    }
    复制代码
    运行:
    C:work>java WhichChars
    [ Hdouwy]

    例2:筛选法求素数
    1. import java.util.*;
    2. public class BitSetTest{
    3.    public static void main(String[] args){
    4.       BitSet sieve=new BitSet(1024);
    5.       int size=sieve.size();
    6.       for(int i=2;i< size;i++)
    7.            sieve.set(i);
    8.       int finalBit=(int)Math.sqrt(sieve.size());
    9.       
    10.       for(int i=2;i< finalBit;i++)
    11.          if(sieve.get(i))
    12.            for(int j=2*i;j< size;j+=i)
    13.                sieve.clear(j);
    14.       
    15.       int counter=0;
    16.       for(int i=1;i< size;i++){
    17.           if(sieve.get(i)){
    18.              System.out.printf("%5d",i);
    19.              if(++counter%15==0)
    20.                 System.out.println();
    21.           }
    22.        }
    23.     }
    24. }
    25. C:work>java   BitSetTest
    26.     2    3    5    7   11   13   17   19   23   29   31   37   41   43   47
    27.    53   59   61   67   71   73   79   83   89   97  101  103  107  109  113
    28.   127  131  137  139  149  151  157  163  167  173  179  181  191  193  197
    29.   199  211  223  227  229  233  239  241  251  257  263  269  271  277  281
    30.   283  293  307  311  313  317  331  337  347  349  353  359  367  373  379
    31.   383  389  397  401  409  419  421  431  433  439  443  449  457  461  463
    32.   467  479  487  491  499  503  509  521  523  541  547  557  563  569  571
    33.   577  587  593  599  601  607  613  617  619  631  641  643  647  653  659
    34.   661  673  677  683  691  701  709  719  727  733  739  743  751  757  761
    35.   769  773  787  797  809  811  821  823  827  829  839  853  857  859  863
    36.   877  881  883  887  907  911  919  929  937  941  947  953  967  971  977
    37.   983  991  997 1009 1013 1019 1021
    复制代码
    例3:简单使用
    1. import java.util.BitSet;
    2. public class BitOHoney {
    3.   public static void main(String args[]) {
    4.     String names[] = { "Java", "Source", "and", "Support"};
    5.     BitSet bits = new BitSet();
    6.     for (int i = 0, n = names.length; i < n; i++) {
    7.       if ((names[i].length() % 2) == 0) {
    8.         bits.set(i);
    9.       }
    10.     }
    11.     System.out.println(bits);
    12.     System.out.println("Size : " + bits.size());
    13.     System.out.println("Length: " + bits.length());
    14.     for (int i = 0, n = names.length; i < n; i++) {
    15.       if (!bits.get(i)) {
    16.         System.out.println(names[i] + " is odd");
    17.       }
    18.     }
    19.     BitSet bites = new BitSet();
    20.     bites.set(0);
    21.     bites.set(1);
    22.     bites.set(2);
    23.     bites.set(3);
    24.     bites.andNot(bits);
    25.     System.out.println(bites);
    26.   }
    27. }
    复制代码
    运行:
    C:work>java BitOHoney
    {0, 1}
    Size : 64
    Length: 2
    and is odd
    Support is odd
    {2, 3}



      
      
       
       

         
       

         
       
      
    复制代码

    源码下载:http://file.javaxxz.com/2014/10/29/235617796.zip
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-2-26 01:06 , Processed in 0.355537 second(s), 46 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表