C++ 頭文件系列 (bitset)

来源:http://www.cnblogs.com/lgxZJ/archive/2017/02/10/6384991.html
-Advertisement-
Play Games

簡介 該頭文件有關 位集 ,實際上是vector對應的固定大小版本(fix sized),位的大小在編譯期固定。 位 位本質上對應bool的概念,只有0或1,true或false兩種對立的值。 但很可惜,位元組才是機器上最小的存儲單元,所以bool基本上是由一個位元組大小。 bitset是出於高效的空間 ...


簡介

該頭文件有關位集,實際上是vector

位本質上對應bool的概念,只有0或1,true或false兩種對立的值。 但很可惜,位元組才是機器上最小的存儲單元,所以bool基本上是由一個位元組大小。

bitset是出於高效的空間利用為目的才出現的。

位操作

  • operator [] : 通過下標訪問bit。
  • count : 計數位值為1的位個數。
  • size : 返回位的大小,即有多少個位。
  • test : 測試下標指向的位值是否為1。
  • any : 判斷是否有任何一個位值為1。
  • none : 判斷是否沒有任何一個位值為1.
  • all : 判斷是否所有位值為1.
  • set : 設置某一個位值為1.
  • reset : 重置某一個位值為0.
  • flip : 翻轉某一個位值,即0變1,1變0.

轉換函數

  • to_string : 轉換成字元串。
  • to_ulong : 轉換成unsigned long。
  • to_ullong : 轉換成unsigned long long。

位集操作

在這裡,bitset可以看成以01位代表的整數。 對於整數,我們又很多操作可以執行:亦或左移等等。 頭文件重載了這些操作符,方便我們對位集進行運算:

  • &、&=
  • |、|=
  • ^、^=
  • <<、<<=
  • >>、>>=
  • ~
  • ==
  • !=

reference type

因為C++最小的內置類型大小是1個位元組,而bit概念上只需要1個bit,所以,與vector


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 轉換流 1、轉換流:將位元組流轉換成字元流,轉換之後就可以一個字元一個字元的往程式寫內容了,並且可以調用字元節點流的write(String s)方法,還可以在外面套用BufferedReader()和BufferedWriter,並使用它們的readLine 和 newLine方法。 2、有兩種轉換 ...
  • <?php//生成隨機數 和 時間函數//echo rand();//echo "<br>";//echo rand(0,10);//echo time();//時間戳//2017-02-10 08:46:12date_default_timezone_set("Asia/Shanghai");// ...
  • 總結一下對象的創建過程,假設有一個名為Dog的類: 1. 即使沒有顯示地使用static關鍵字,構造器實際上也是靜態的方法,因此,當首次創建類型為Dog的對象時(構造器可以看成靜態方法),或者Dog類的靜態方法/靜態域首次被訪問時,java解釋器必須查找類的路徑,以定位Dog.class文件。 2. ...
  • Redisson分散式鎖 之前的基於註解的鎖有一種鎖是基本redis的分散式鎖,鎖的實現我是基於redisson組件提供的RLock,這篇來看看redisson是如何實現鎖的。 不同版本實現鎖的機制並不相同 引用的redisson最近發佈的版本3.2.3,不同的版本可能實現鎖的機制並不相同,早期版本 ...
  • 要求: 1 #_*_coding:utf-8_*_ 2 #第一部分:sql解析 3 import os,time 4 def sql_parse(sql): 5 ''' 6 sql_parse >insert_parse,delete_parse,update_parse,select_parse ...
  • 先初始化主類中的靜態數據,如果要用其他類來定義對象,則初始化對應的其他類。 實例化對象時,先初始化定義為static的數據,再初始化定義為非static的數據,最後調用構造函數。 通過一個小程式,瞭解靜態數據是如何初始化的: 初始化順序:要執行main,必須先載入StaticInitializati ...
  • 一、新建Maven Module測試站點 \ 二、配置Application Server 1.File->Setting,打開設置面板; 2.選中Application Servers,點擊+,設置tomcat路徑,指向本機Tomcat所在目錄。如下圖所示: 三、設置Run Configurati ...
  • 之前寫過一篇用jsoup爬取csdn博客的文章JAVA爬蟲挖取CSDN博客文章 ,當時博主還在上一家公司實習,由於公司辦公網路需要代理才能訪問外網,那一篇的代碼邏輯與代理密切相關,可能有些不熟悉jsoup怎麼使用的朋友看了會感覺越看越糊塗,且當時以為爬取所有文章需要用到分頁,可能會誤導讀者。所以今天... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...