位集合(STL bitset)简介

【bitset 官方网址】
https://cplusplus.com/reference/bitset/bitset/
位集合(Bit Set)是一种高效存储和操作布尔值(true/false)或二进制位(0/1)的数据结构,主要用于处理大规模整数集合或状态标志。


【bitset 各函数用法简介】
● 初始化 → 
https://cplusplus.com/reference/bitset/bitset/operator[]/

#include <bits/stdc++.h>
using namespace std;int main () {bitset<5> foo;    //00000foo[1]=1;         //00010foo[2]=foo[1];    //00110cout<<foo<<endl;  //00110return 0;
}

● std::bitset::count → https://cplusplus.com/reference/bitset/bitset/count/
count() 函数统计 01 串中 1 的个数。

#include <bits/stdc++.h>
using namespace std;int main () {bitset<8> foo(string("10110011"));cout<<foo<<"\n";cout<<foo.count()<<" ones.\n";cout<<(foo.size()-foo.count())<<" zeros.\n";return 0;
}/*
10110011
5 ones.
3 zeros.
*/

● std::bitset::size → https://cplusplus.com/reference/bitset/bitset/size/
size() 函数返回 01 串的长度。

#include <bits/stdc++.h>
using namespace std;int main () {bitset<8> foo;bitset<4> bar;cout<<foo.size()<<'\n'; //8cout<<bar.size()<<'\n'; //4return 0;
}

​​​​​​​●​​​​​​​ std::bitset::test → https://cplusplus.com/reference/bitset/bitset/test/
cout<<boolalpha; 是 C++ 中的一条语句,用于设置 cout 的输出格式,使其在输出布尔值时显示为 true 或 false(而不是默认的 1 或 0)。

#include <bits/stdc++.h>
using namespace std;int main () {bitset<5> foo(string("01011"));cout<<boolalpha; //emphasisfor(int i=0; i<foo.size(); i++) {cout<<foo.test(i)<<'\n';}return 0;
}/*
true
true
false
true
false
*/

● std::bitset::set → https://cplusplus.com/reference/bitset/bitset/set/
利用 set() 将所有位的值设为 1。
利用 set(x) 将第 x 位的值设为 1。(
从右往左计位,最右边的位序为 0
利用 set(x,0) 将第 x 位的值设为 0。

#include <bits/stdc++.h>
using namespace std;int main () {bitset<5> foo;cout<<foo.set()<<'\n';       //11111cout<<foo.set(2,0)<<'\n';    //11011cout<<foo.set(2)<<'\n';      //11111return 0;
}

● std::bitset::reset → https://cplusplus.com/reference/bitset/bitset/reset/
利用 reset(x) 将第 x 位的值设为 0。从右往左计位,最右边的位序为 0
利用 reset() 将所有位的值设为 0。

#include <bits/stdc++.h>
using namespace std;int main () {bitset<5> foo(string("10111"));cout<<foo.reset(2)<<'\n';  //10011cout<<foo.reset()<<'\n';   //00000return 0;
}

● std::bitset::flip → https://cplusplus.com/reference/bitset/bitset/flip/
flip() 函数将 0 置为 1,将 1 置为 0。

#include <bits/stdc++.h>
using namespace std;int main () {bitset<5> foo(string("10001"));cout<<foo.flip(2)<<'\n';   //10101cout<<foo.flip()<<'\n';    //01010return 0;
}

● std::bitset::all → https://cplusplus.com/reference/bitset/bitset/all/
all:01 串中各位都是 1;
any:01 串中至少有一位是 1;
none:01 串中没有 1。

#include <bits/stdc++.h>
using namespace std;int main () {bitset<8> foo;cin>>foo; //11111111cout<<boolalpha;cout<<"all: "<<foo.all()<<'\n'; //truecout<<"any: "<<foo.any()<<'\n'; //truecout<<"none: "<<foo.none()<<'\n'; //falsereturn 0;
}




【参考文献】
https://cplusplus.com/reference/bitset/bitset/



 

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

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

相关文章

基于SDN环境下的DDoS异常攻击的检测与缓解

参考以下两篇博客&#xff0c;最后成功&#xff1a; 基于SDN的DDoS攻击检测和防御方法_基于sdn的ddos攻击检测与防御-CSDN博客 利用mininet模拟SDN架构并进行DDoS攻击与防御模拟&#xff08;Ryumininetsflowpostman&#xff09;_mininet模拟dos攻击-CSDN博客 需求 H2 模拟f…

责任链模式:构建灵活可扩展的请求处理体系(Java 实现详解)

一、责任链模式核心概念解析 &#xff08;一&#xff09;模式定义与本质 责任链模式&#xff08;Chain of Responsibility Pattern&#xff09;是一种行为型设计模式&#xff0c;其核心思想是将多个处理者对象连成一条链&#xff0c;并沿着这条链传递请求&#xff0c;直到有某…

如何进行页面前端监控

&#x1f9d1;‍&#x1f4bb; 写在开头 点赞 收藏 学会&#x1f923;&#x1f923;&#x1f923; 前端监控主要分三个方向 前端性能&#xff08;用户体验优化&#xff09; 异常监控 业务指标跟 下面我来分别介绍三类指标如何获取 1&#xff09;前端性能指标&#xff1a; …

Ajax技术分析方法全解:从基础到企业级实践(2025最新版)

引言 Ajax技术自2005年正式命名以来,已支撑全球83%的Web应用实现异步交互。2025年最新数据显示,单页面应用(SPA)的Ajax请求密度已达日均120亿次/应用。本文将系统化解析Ajax分析方法论,涵盖从基础原理到企业级工程实践的完整技术栈。 一、Ajax技术架构解构 1.1 核心组件…

git管理github上的repository

1. 首先注册github并创建一个仓库&#xff0c;这个很简单&#xff0c;网上教程也很多&#xff0c;就不展开说了 2. 安装git&#xff0c;这个也很简单&#xff0c;不过这里有个问题就是你当前windows的用户名即&#xff1a;C/Users/xxx 这个路径不要有中文&#xff0c;因为git …

Windows 下部署 SUNA 项目:虚拟环境尝试与最终方案

#工作记录 #回顾总结 本文记录了在 Windows 系统上&#xff0c;通过 PyCharm 图形界面&#xff08;尽量减少命令行操作&#xff09;部署 SUNA 项目时&#xff0c;针对不同虚拟环境方案的尝试过程、遇到的问题以及最终选择的可行方案&#xff0c;并补充了整体部署思路与推荐。…

无向图的点、边双连通分量

文章目录 点双连通分量边双连通分量 有向图的强连通分量&#xff1a;寒假学习笔记【匠心制作&#xff0c;图文并茂】——1.20拓扑、强连通分量、缩点 点双连通分量 在这之前&#xff0c;先让我们了解几个概念。 割点&#xff1a;删除一个点和其连出的边后&#xff0c;原图会…

第六十二节:深度学习-加载 TensorFlow/PyTorch/Caffe 模型

在计算机视觉领域,OpenCV的DNN(深度神经网络)模块正逐渐成为轻量级模型部署的利器。本文将深入探讨如何利用OpenCV加载和运行三大主流框架(TensorFlow、PyTorch、Caffe)训练的模型,并提供完整的代码实现和优化技巧。 一、OpenCV DNN模块的核心优势 OpenCV的DNN模块自3.3…

Spring @Autowired自动装配的实现机制

Spring Autowired自动装配的实现机制 Autowired 注解实现原理详解一、Autowired 注解定义二、Qualifier 注解辅助指定 Bean 名称三、BeanFactory&#xff1a;按类型获取 Bean四、注入逻辑实现五、小结 源码见&#xff1a;mini-spring Autowired 注解实现原理详解 Autowired 的…

胜牌™全球成为2026年FIFA世界杯™官方赞助商

胜牌全球将首次与国际足联&#xff08;FIFA&#xff09;旗舰赛事建立合作关系。 此次赞助恰逢美国首个润滑油品牌即将迎来160周年之际&#xff0c;其国际扩张步伐正在加快。 在这项全球顶级赛事筹备期间&#xff0c;胜牌全球将通过各种富有创意的零售和体验活动与球迷互动。 …

YOLOV7改进之融合深浅下采样模块(DSD Module)和轻量特征融合模块(LFI Module)

目录 一、研究背景​ 二. 核心创新点​ ​2.1 避免高MAC操作​ ​2.2 DSDM-LFIM主干网络​ 2.3 P2小目标检测分支​ ​3. 代码复现指南​ 环境配置 关键修改点 ​4. 实验结果对比​ 4.1 VisDrone数据集性能 4.2 边缘设备部署 4.3 检测效果可视化 ​5. 应用场景​ …

【C/C++】chrono简单使用场景

chrono使用场景举例 1 输出格式化字符串 示例代码 auto now std::chrono::system_clock::now(); auto t std::chrono::system_clock::to_time_t(now); auto ms std::chrono::duration_cast<std::chrono::milliseconds>(now.time_since_epoch()) % 1000;std::ostrin…

Med-R1论文阅读理解-1

论文总结&#xff1a;Med-R1: Reinforcement Learning for Generalizable Medical Reasoning in Vision-Language Models 论文写了什么&#xff1f; 本文提出了一种名为 Med-R1 的新框架&#xff0c;旨在通过强化学习&#xff08;Reinforcement Learning, RL&#xff09;提升…

京东热点缓存探测系统JDhotkey架构剖析

热点探测使用场景 MySQL 中被频繁访问的数据 &#xff0c;如热门商品的主键 IdRedis 缓存中被密集访问的 Key&#xff0c;如热门商品的详情需要 get goods$Id恶意攻击或机器人爬虫的请求信息&#xff0c;如特定标识的 userId、机器 IP频繁被访问的接口地址&#xff0c;如获取用…

MCU_IO驱动LED

注意事项&#xff1a; 1、亮度要求较高的情况下&#xff0c;不能由IO直接驱动LED MCU_IO引脚输出的电压和电流较弱&#xff0c;如果对光的亮度有要求的话&#xff0c;需要使用三极管来驱动。 MCU_IO的电压一般为3.3V或者5V&#xff0c;输出电流一般10mA-25mA。 2、不同颜色…

MyBatis 深度解析:高效 Java 持久层框架实践指南(基于 3.5.10)

一、MyBatis 核心架构与设计哲学 MyBatis 作为半自动 ORM 框架&#xff0c;核心设计目标是在灵活性与开发效率之间取得平衡。与 Hibernate 等全自动 ORM 框架不同&#xff0c;MyBatis 允许开发者完全控制 SQL 编写&#xff0c;同时通过映射机制减少重复代码&#xff0c;特别适…

二叉树(二)

98.验证二叉树 中序遍历二叉树&#xff0c;每次遍历存下当前节点的值&#xff0c;遍历到下一个节点比较&#xff0c;根据二叉搜索树的特性&#xff0c;左<中<右有&#xff1a; 如果当前值小于或等于上一个的值&#xff0c;说明不是二叉搜索树 如果当前值大于上一个节点…

解决Vue3+uni-app导航栏高亮自动同步方案

路由跳转自动识别导航高亮实现方法 以下代码使用wd-tabbar组件实现路由跳转时自动同步导航栏高亮状态&#xff0c;适用于所有的Vue3uni-app项目。 请根据自身使用框架类型完成&#xff0c;也可根据我使用的UI组件进行完成地址如下&#xff1a; Tabbar 标签栏 | Wot UI &#…

免费论文查重与AI检测工具推荐

文章目录 概要一、PaperPass二、PaperYY注意 概要 毕业季&#xff0c;总少不了查重这一步&#xff0c;甚至查 AI 率。推荐两款免费查重AIGC检测的工具。 论文免费查重查AI&#xff1a; https://paperpass.com/ https://www.paperyy.com/ 一、PaperPass 网址&#xff1a; ht…

4、ubuntu系统 | 文本和目录操作函数

1、目录操作函数 ls(列出目录内容) 用途:列出指定目录中的文件和子目录。语法:ls [选项] [路径]常用选项: -l:以长格式显示文件详细信息(权限、所有者、大小、时间等)。-a:显示隐藏文件(以.开头的文件)。-R:递归列出子目录内容。# 列出当前目录下的所有文件和子目…