zoukankan      html  css  js  c++  java
  • C++标准库bitset类型(简单使用方法)

    转自此人博客

    ```cpp

    #include<bister>

    using std::bitset;

    ```

    一句话定义:可自定义位数,用作记录二进制的数据类型.

    一,定义和初始化

    ```cpp

     bitset<n> b;                           //b有n位,每位都为0;

     bitset<n> b(u);                       //b是unsigned long型u的副本

     bitset<n> b(s);                       //b是string对象s中含有n位字符串的副本

     bitset<n> b(s, pos, n);             //b是s中从pos位置开始的n个位置的副本

     bitset<n> b(s,pos);                 //b从s的pos位置开始取值到s末尾(注取的值从b的右端开始)

    ```

     注:①n定义的位数在初始化时按初始值填充,赋值超出的范围舍去,空余的以零填充.

             ②bitset从string对象读入位集时按从右到左的顺序.

    二,操作

    ```cpp

     b.any();                                 //查找b是否存在1?

     b.none();                               //b中不存在1吗?

     b.count();                              //b中1的个数

     b.size();                                //b的位数

     b[pos];                                 //访问b中pos处的数值

     b.test(pos);                          //检测b中pos处是否为1

     b.set();                                //把b中所有位 置为1

     b.set(pos);                           //把b中pos位置为1

     b.reset();                             //把b中所有位置为0

     b.reset(pos);                         //把b中pos位置为0

     b.flip();                                //b中所有二进制位取反

     b.flip(pos);                           //b中在pos处的二进制位取反

     b.to_ulong;                           //返回一个同值得unsigned long值

     os << b;                              //把b中位集输出

     ```

  • 相关阅读:
    数据特征分析:5.相关性分析
    数据特征分析:4.正态分布与正态性检验
    go-文件操作
    图-迪杰斯特拉算法
    图-克鲁斯卡尔算法
    图-普利姆算法
    go-客户信息关系系统
    go-家庭收支记账软件例子
    采用邻接表表示图的深度优先搜索遍历
    广度优先搜索遍历连通图
  • 原文地址:https://www.cnblogs.com/zjp-shadow/p/7224719.html
Copyright © 2011-2022 走看看