c++ 标准库bitset类型

1.bitset对象的定义及初始化:

eg:bitset<32> a;//a的大小为32位二进制

bitset<16> b(0xffff);//b的大小位16位,且初值为0xffff(括号中为赋值,可为任何进制,计算机会进行自动的转化)

string str("1011111000011111000000111000");

bitset<32> f(str,5,4);//从str末尾开始(注意第一位为结束符),第五位开始,保留4位

2.bitset操作:

a.any();//检查a中是否有1,有的话返回1;没有返回0

a.none();//检查a中是否全为0,是的话返回1;不是返回0

a.count();//检查a中一共有几个1

a.size();//a的大小为多少

a[x];//对a中的x位进行操作

a.set(x);//将a中的x位置一

a.set();//将a中的所有位置一

a.reset(x);//将a中的x位置0

a.reset();//将a中的所有位置0

a.flip(x);//将a中的所有位翻转

a.flip();//将a中的所有位翻转

a.to_ulong();//将a转换为一个十进制数

3.标准库bitset应用实例---埃拉托斯特尼"筛法"(寻找质数)

int const max_number(100);


bitset<max_number+1> numbers;//101个0
numbers.set();//101个1
numbers[1]=0;


for(int i(1);i!=max_number;++i)
{
if(numbers[i])
{
for(int j(i*2);j<max_number+1;j+=i)
{
numbers[j]=0;

}

}


}


cout<<numbers.count()<<endl;
   
for(int l(1);l<max_number+1;++i)
{
if(numbers[i]) cout<<i<<",";

}
    cout<<endl;


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值