使用Java BitSet 類實現位集合操作

一、BitSet 類概述

Java BitSet 類表示一組簡單的開關或標誌。它內部由一個長整型數組(long[])實現,其中每個元素都代表64位的二進制數,這些二進制數的每一位可看作一個開關,開關只有兩種狀態,即打開(1)和關閉(0)。可以通過調整這些開關的狀態,來進行一些位運算操作。BitSet 類封裝的是一組位,因此集合運算也可以被實現。該類是線程安全的。

二、BitSet 類的常用方法

1.void set(int index)

將指定的位設置為 true。index 參數表示要設置的位的索引(第一個位的索引是0),該方法不會返回任何值。

BitSet bitSet = new BitSet(8);
bitSet.set(0);
bitSet.set(2);
System.out.println(bitSet); // 輸出{0, 2}

2.void clear(int index)

將指定的位設置為 false。index 參數表示要清除的位的索引(第一個位的索引是0),該方法不會返回任何值。

BitSet bitSet = new BitSet(8);
bitSet.set(0);
bitSet.set(2);
bitSet.clear(2);
System.out.println(bitSet); // 輸出{0}

3.boolean get(int index)

返回指定位的值。index 參數表示要查詢的位的索引(第一個位的索引是0),如果該位是開啟的則返回 true,否則返回 false。

BitSet bitSet = new BitSet(8);
bitSet.set(0);
System.out.println(bitSet.get(0)); // 輸出true

4.int nextClearBit(int fromIndex)

返回第一個未被設置為開啟的位的索引(第一個位的索引是0),該索引的值大於或等於 fromIndex。如果不存在這樣的索引,則返回 bitSet 的大小:length()

BitSet bitSet = new BitSet(8);
bitSet.set(0);
bitSet.set(3);
int index = bitSet.nextClearBit(0);
System.out.println(index); // 輸出1

5.String toString()

將 BitSet 轉換成 String 類型。該方法返回包含所有位狀態的字符串。0 表示關閉狀態,1 表示開啟狀態,左邊的位是最高有效位。

BitSet bitSet = new BitSet(8);
bitSet.set(0);
bitSet.set(2);
System.out.println(bitSet.toString()); // 輸出“00000101”

三、在實際應用中使用 BitSet 類

1. 應用場景1:少量整數的排序

如果需要對一個不大的整數集合進行排序,將集合中的每個值作為 BitSet 的索引,可以方便地進行排序。下面的示例中,我們將整數集合{1,3,5,7,9}排序:

BitSet bitSet = new BitSet();
int[] arr = {1,3,5,7,9};
for (int i : arr) {
    bitSet.set(i);
}
for (int i = 0; i < bitSet.size(); i++) {
    if (bitSet.get(i)) {
        System.out.print(i + " ");
    }
} // 輸出“1 3 5 7 9”

2. 應用場景2:按位存儲和傳輸數據

在某些情況下,需要按位存儲和傳輸數據。應用 BitSet 類可以方便地進行這些操作。下面是一個示例,我們使用 BitSet 類按位存儲和傳輸 5 個字節的數據,然後再將其轉換回字節形式:

BitSet bitSet = new BitSet();
byte[] bytes = {0b00010011, 0b01010101, 0b10101010, (byte) 0b11001100, (byte) 0b11110000};
for (int i = 0; i < bytes.length; i++) {
    for (int j = 0; j < 8; j++) {
        int val = bytes[i] & (1 < 0) {
            bitSet.set(i * 8 + j);
        }
    }
}
System.out.println(bitSet); // 輸出{0, 2, 4, 6, 8, 10, 12, 16, 18, 20, 22, 26, 27, 28, 29, 30}
byte[] newBytes = new byte[5];
for (int i = 0; i < bitSet.size(); i += 8) {
    byte b = 0;
    for (int j = 0; j < 8; j++) {
        if (bitSet.get(i + j)) {
            b |= 1 << j;
        }
    }
    newBytes[i / 8] = b;
}
System.out.println(Arrays.toString(newBytes)); // 輸出“[19, 85, -86, -52, -16]”

3. 應用場景3:判斷兩個集合的交集和並集

使用 BitSet 類可以方便地實現位運算,進而實現原本需要較長的代碼實現的集合操作。下面的示例中,我們新建兩個 BitSet 類型的集合 bitSet1 和 bitSet2,其中 bitSet1 包含索引值為 1、3、5 和 7 的四個位,bitSet2 包含索引值為 3、4 和 5 的三個位。我們使用 and() 方法得到 bitSet1 和 bitSet2 的交集,使用 or() 方法得到 bitSet1 和 bitSet2 的並集:

BitSet bitSet1 = new BitSet();
BitSet bitSet2 = new BitSet();
bitSet1.set(1);
bitSet1.set(3);
bitSet1.set(5);
bitSet1.set(7);
bitSet2.set(3);
bitSet2.set(4);
bitSet2.set(5);
BitSet andBitSet = (BitSet) bitSet1.clone();
andBitSet.and(bitSet2);
System.out.println(andBitSet); // 輸出{3, 5}
BitSet orBitSet = (BitSet) bitSet1.clone();
orBitSet.or(bitSet2);
System.out.println(orBitSet); // 輸出{1, 3, 4, 5, 7}

四、總結

本文介紹了使用 Java BitSet 類實現位集合操作的概念和常用方法,並提供了三個常見的應用場景。通過對 BitSet 類的使用,我們可以更方便地進行位運算和集合運算。在實際應用中,需要根據實際需求選擇合適的方法和算法。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/183100.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-11-24 16:26
下一篇 2024-11-24 16:26

相關推薦

  • java client.getacsresponse 編譯報錯解決方法

    java client.getacsresponse 編譯報錯是Java編程過程中常見的錯誤,常見的原因是代碼的語法錯誤、類庫依賴問題和編譯環境的配置問題。下面將從多個方面進行分析…

    編程 2025-04-29
  • Java JsonPath 效率優化指南

    本篇文章將深入探討Java JsonPath的效率問題,並提供一些優化方案。 一、JsonPath 簡介 JsonPath是一個可用於從JSON數據中獲取信息的庫。它提供了一種DS…

    編程 2025-04-29
  • Java Bean加載過程

    Java Bean加載過程涉及到類加載器、反射機制和Java虛擬機的執行過程。在本文中,將從這三個方面詳細闡述Java Bean加載的過程。 一、類加載器 類加載器是Java虛擬機…

    編程 2025-04-29
  • Java騰訊雲音視頻對接

    本文旨在從多個方面詳細闡述Java騰訊雲音視頻對接,提供完整的代碼示例。 一、騰訊雲音視頻介紹 騰訊雲音視頻服務(Cloud Tencent Real-Time Communica…

    編程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介紹

    本文將詳細介紹Java Milvus SearchParam withoutFields的相關知識和用法。 一、什麼是Java Milvus SearchParam without…

    編程 2025-04-29
  • Python棧操作用法介紹

    如果你是一位Python開發工程師,那麼你必須掌握Python中的棧操作。在Python中,棧是一個容器,提供後進先出(LIFO)的原則。這篇文章將通過多個方面詳細地闡述Pytho…

    編程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java語言中的一個版本,於2014年3月18日發布。本文將從多個方面對Java 8中某一周的周一進行詳細的闡述。 一、數組處理 Java 8新特性之一是Stream…

    編程 2025-04-29
  • Java判斷字符串是否存在多個

    本文將從以下幾個方面詳細闡述如何使用Java判斷一個字符串中是否存在多個指定字符: 一、字符串遍歷 字符串是Java編程中非常重要的一種數據類型。要判斷字符串中是否存在多個指定字符…

    編程 2025-04-29
  • VSCode為什麼無法運行Java

    解答:VSCode無法運行Java是因為默認情況下,VSCode並沒有集成Java運行環境,需要手動添加Java運行環境或安裝相關插件才能實現Java代碼的編寫、調試和運行。 一、…

    編程 2025-04-29
  • Java任務下發回滾系統的設計與實現

    本文將介紹一個Java任務下發回滾系統的設計與實現。該系統可以用於執行複雜的任務,包括可回滾的任務,及時恢復任務失敗前的狀態。系統使用Java語言進行開發,可以支持多種類型的任務。…

    編程 2025-04-29

發表回復

登錄後才能評論