本来仅仅只是用来做哈夫曼实验时的辅助,后来一想干脆封装好,省得以后又要用到比特位的操作。

基本用法示例:

 BitArray bits;
 bits[] = ;
 bits[] = ;
 cout<<bits[]<<endl;  ]<<endl;  ]<<endl; ){}
)/+;}
*bytes;}
             size_t setBitCapacity(size_t newBitsCapacity);
            size_t getBitSize(){            size_t getBitCapacity(){            size_t getByteSize(){            size_t getByteCapacity(){                                   uchar * m_data;
          size_t m_bitsLength;
          size_t m_bitsCapacity;
           };
 #endif 

1 #include "BitArray.h"

;
){
;
,t_bytesLength);
*t_bytesLength;
*t_fact_bytesCapacity;
,t_fact_bytesCapacity);
;i<m_bitsLength;i++){
      }
 
 BitArray::BitArray(unsigned  {
     m_data = data;
     m_bitsLength = bitsLength;
     m_bitsCapacity = *BitsToBytes(m_bitsLength);
     m_owns = isOwns;
     size_t t_bytesLength = BitsToBytes(m_bitsLength);
              memset(m_data,,t_bytesLength);
 }
 
               delete[] m_data;
     m_data = data;
     m_bitsLength = bitsLength;
     m_bitsCapacity = *BitsToBytes(m_bitsLength);
     m_owns = isOwns;
     size_t t_bytesLength = BitsToBytes(m_bitsLength);
              memset(m_data,,t_bytesLength);
 }
 
  {
                             }
                     }
                   }
      ){
         position += m_bitsLength; 
     }
                    }          ;
              }         size_t t_new_bitsLength = position+;
         size_t t_new_bytesCapacity = BitsToBytes(c_increaseCapacity*t_new_bitsLength);
         size_t t_new_bitsCapacity = *t_new_bytesCapacity;
         uchar* t_data =                                  memset(t_data,,t_new_bytesCapacity);
         memcpy(t_data,m_data,BitsToBytes(m_bitsCapacity));
                      delete[] m_data;
         }
         m_data = t_data;
         m_bitsCapacity = t_new_bitsCapacity;
         m_bitsLength = t_new_bitsLength;
         m_owns =               }
 }
 
  {
                    }
      && position >= -(               }
      }
 
 size_t BitArray::setBitSize(size_t newBitsLength)
 {
     size_t origin_bitsLength = m_bitsLength;
              m_bitsLength = newBitsLength;
     }          ,     }
      }
 
 size_t BitArray::setBitCapacity(size_t newBitsCapacity)
 {
               size_t new_bytesCapacity = BitsToBytes(newBitsCapacity);
              uchar* t_data =                                  memset(t_data,,new_bytesCapacity);
                            }                   }
                      delete[] m_data;
         }
         m_data = t_data;
         m_bitsCapacity = BytesToBits(new_bytesCapacity);
                      m_bitsLength = m_bitsCapacity;
         }
         m_owns =      }
      }
 
  {
          m_owns = owns;
      }
 
     {
      ;    
      - (position) % ; 
              map[sub] |= <<pos;                  map[sub] &= ~(<<pos);           }
 
     {
      ;
      - (position)%;
      );
 }
 
 Bit::Bit(BitArray *bits,     m_bits = bits;
     m_position = position;
 }
 
 Bit& Bit::     m_bits->      }
 
 Bit::      }

一个封装好的C++比特数组BitArray,可以对位进行直接操作的更多相关文章

  1. java—数组乘积输入: 一个长度为n的整数数组input 输出: 一个长度为n的数组result,满足result[i] = input数组中,除了input[i] 之外的所有数的乘积,不用考虑溢出例如 input {2, 3, 4, 5} output: {60, 40, 30, 24}

    /** * 小米关于小米笔试题 数组乘积输入: 一个长度为n的整数数组input 输出: 一个长度为n的数组result,满足result[i] = * input数组中,除了input[i] 之外的 ...

  2. 字符串string和内存流MemoryStream及比特数组byte[]互转

    原文:字符串string和内存流MemoryStream及比特数组byte[]互转   字符串string和内存流MemoryStream及比特数组byte[]互转比较 定义string变量为str, ...

  3. 每天一个JavaScript实例-递归实现反转数组字符串

    <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...

  4. 使用jQuery匹配文档中所有的li元素,返回一个jQuery对象,然后通过数组下标的方式读取jQuery集合中第1个DOM元素,此时返回的是DOM对象,然后调用DOM属性innerHTML,读取该元素 包含的文本信息

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  5. 一个封装的使用Apache HttpClient进行Http请求(GET、POST、PUT等)的类。

    一个封装的使用Apache HttpClient进行Http请求(GET.POST.PUT等)的类. import com.qunar.payment.gateway.front.channel.mp ...

  6. 【c语言】数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字

    题目:数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字. 比如输入一个长度为9的数组{1,2.3.2,2.2.5,4.2}, 因为数组中数字2出现了5次,超过数组的长度的一半,因此输出2 ...

  7. JavaScript实现生成指定范围随机数和一个包含不重复数的随机数组

    目前JavaScript里面还没有现成的方法可以实现这个简单地需求,我们就需要自己写代码了. 在js中有个函数:Math.random() 这个函数可以生成 [0,1) 的一个随机数. 我们的简单的改 ...

  8. C# 字符串string和内存流MemoryStream及比特数组byte[]之间相互转换

    定义string变量为str,内存流变量为ms,比特数组为bt 1.字符串转比特数组 复制代码 代码如下: (1)byte[] bt=System.Text.Encoding.Default.GetB ...

  9. Day_09【常用API】扩展案例1_程序中使用一个长度为3的对象数组,存储用户的登录名和密码……

    需求说明:实现用户注册.登陆功能: 1.程序中使用一个长度为3的**对象数组**,存储用户的登录名和密码: 例如如下格式: 登录名 密码 生日 爱好 zhangsan 1111 1998-03-15 ...

随机推荐

  1. Android-WizardPager

    https://github.com/HeinrichReimer/Android-WizardPager

  2. [AngularJS] Html ngSanitize, $sce

    Safely render arbitrary HTML snippets by using ngSanitize and $sce. By default angularJS consider us ...

  3. android147 360 程序锁

    <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android=&quo ...

  4. c#_自动化测试 (五) 读写64位操作系统的注册表

    非Web程序(桌面程序)的设置一般都存在注册表中. 给这些程序做自动化测试时, 需要经常要跟注册表打交道. 通过修改注册表来修改程序的设置. 本章介绍如何利用C#程序如何操作注册表, 特别是如何操作6 ...

  5. C++_快速排序(纯C版本)

    //比较大小 static int compare_int(const void *int1,const void *int2) { if(*(const int*)int1>*(const i ...

  6. Eclipse常用快捷键集合

    一.通用快捷键 [ALT+/]   此快捷键为用户编辑的神级好帮手,能为用户提供内容的辅助,不要为记不全方法和属性名称犯愁下 [Ctrl+T] 搜索当前接口的实现类 [Ctrl+O]  显示类中方法和 ...

  7. 想学React Native?你只需要一个App!(11月5号更新)

    最近有点空闲时间,顺手研究下react-native,2013年的时候在老师的指导下使用jQuery Mobile做过手机应用,那个运行速度慢呀!让我对WebApp和PhoneGap这一类的跨平台Ap ...

  8. 数据结构笔记02:Java面试必问算法题

    1. 面试的时候,栈和队列经常会成对出现来考察.本文包含栈和队列的如下考试内容: (1)栈的创建 (2)队列的创建 (3)两个栈实现一个队列 (4)两个队列实现一个栈 (5)设计含最小函数min()的 ...

  9. Android(java)学习笔记102:Map集合功能概述

    下面通过代码引入Map集合:如下 package cn.itcast_01; import java.util.HashMap; import java.util.Map; /* * 作为学生来说,是 ...

  10. Android(java)学习笔记84:自定义异常类

    自定义异常: 考试成绩必须在0-100之间 很明显java没有对应的异常,需要我们自己来做一个异常 自定义异常 继承自Exception 继承自RuntimeException 下面是一个代码示例: ...