C++ 遇见的一些函数

1.位与(&)操作,计算十进制数中的为“1”的位数

int cnt_one(int k)
{
    int c = 0;        //保存位为"1"的数量
    while (k) {
        k = k&(k - 1);        //这样就能实现求出位为"1"的个数
        c++;
    }
    return c;
}

PS:关于位的操作补充:C++ bitset类

(1)bitset定义及初始化

bitset<32> bitvar; //32位,全为0。

(2)bitset操作(bitset<32> bitvec; // 32 bits, all zero)

bitset操作
b.any() b中是否存在置为1的二进制位?    bool is_set = bitvec.any();            // false, all bits are zero
b.none() b中不存在置为1的二进制位吗?    bool is_not_set = bitvec.none();      // true, all bits are zero
b.count() b中置为1的二进制位的个数      size_t bits_set = bitvec.count(); // returns number of bits that are on返回二进制位中为“1”的数量
b.size() b中二进制位的个数           size_t sz = bitvec.size(); // returns 32
b[pos] 访问b中在pos处的二进制位  for (int index = 0; index != 32; index += 2)  bitvec[index] = 1;把bitvec中的偶数下标的位都置为1
b.test(pos) b中在pos处的二进制位是否为1?   if (bitvec.test(i))    bitvec[i] is on    //测试某个二进制位是否为“1”
b.set() 把b中所有二进制位都置为1 bitvec.set();    // set all the bits to 1  for (int index = 0; index != 32; index += 2)   bitvec.set(index);    //设置二进制位的值
b.set(pos) 把b中在pos处的二进制位置为1    
b.reset() 把b中所有二进制位都置为0      bitvec.reset();    // set all the bits to 0
b.reset(pos) 把b中在pos处的二进制位置为0
b.flip() 把b中所有二进制位逐位取反      bitvec.flip();    // reverses value of all bits
b.flip(pos) 把b中在pos处的二进制位取反      bitvec.flip(0);   // reverses value of first bit
b.to_ulong() 用b中同样的二进制位返回一个unsigned long值
os << b
把b中的位集输出到os流    bitset<32> bitvec2(0xffff); // bits 0 ... 15 are set to 1; 16 ... 31 are 0     cout << "bitvec2: " << bitvec2 << endl;

result:    bitvec2: 00000000000000001111111111111111

2.

时间: 2024-12-31 06:16:37

C++ 遇见的一些函数的相关文章

matlab学习笔记 bsxfun函数

matlab学习笔记 bsxfun函数 最近总是遇到 bsxfun这个函数,前几次因为无关紧要只是大概看了一下函数体去对比结果,今天再一次遇见了这个函数,想想还是有必要掌握的,遂查了些资料总结如下.   函数bsxfun [功能描述]两个数组间元素逐个计算. [应用场合]当我们想对一个矩阵A的每一列或者每一行与同一个长度相等的向量a进行某些操作(比较大小,乘除等)时,我们只能用循环方法或者利用repmat函数将要操作的向量a复制成和A一样尺寸的矩阵,进而进行操作.从MATLAB R2007a开始

python(动态传参、命名空间、函数嵌套、global和nonlocal关键字)

一.函数的动态传参 1.*args位置参数动态传参 def chi(*food): print(food) chi("烧烤","火锅","虾吃虾涮","烤鱼") 多个位置参数传递进去,收到的内容是元组tuple,动态参数的位置必须要在位置参数后面 2**kwargs 关键字参数动态传参 def chi(**food): print(food) chi(zhangqing="吃点好的",lianda=&quo

函数的嵌套与global和nonlacal

一. 函数的嵌套 只要遇见了()就是函数的调用. 如果没有()就不是函数的调用 函数的执行顺序 def fun1(): print(111) def fun2(): print(222) fun1() fun2() print(111) def fun2(): print(222) def fun3(): print(666) print(444) fun3() print(888) print(33) fun2() print(555) # 函数中套函数 def func(): a = 1 d

Python进阶函数

一.函数的动态参数 之前我们说过了传参, 如果我们需要给一个函数传参, 而参数又是不确定的. 或者我给一个函数传很多参数, 我的形参就要写很多, 很麻烦, 怎么办呢. 我们可以考虑使用动态参数. 动态参数分成两种: 1. *args 动态接收位置参数 动态接收参数的时候要注意:动态参数必须在位置参数后面 1 def xue(*language,'a','b'): 2 3 print('我要学:',language,a,b) 4 5 xue('PHP',JAVA,'Python') 如果这个程序不

python基础之函数(动态参数,注释,名称空间,第一类对象及使用和函数嵌套)

函数的动态参数 1.函数的动态参数 位置参数,默认参数 动态参数的作用 *args ? 1.能够接受不固定长度参数 ? 2.位置参数过多时可以使用动态参数 动态参数的用法: def func(*c): #形参位置上的 * 是聚会 print(*c) #函数体中的 * 就是打散 #func(1,2,3,4,5,6,7,8,9,0) **def eat(a,b,*args): #位置参数,动态位置参数** print(a,b,args) #结果:面条 包子 ('饺子', '馅饼', '馒头') pr

Oracle分析函数介绍

Oracle的分析函数功能非常强大,工作这些年来经常用到.这次将平时经常使用到的分析函数整理出来,以备日后查看. 我们拿案例来学习,这样理解起来更容易一些. 1.建表 create table earnings -- 打工赚钱表 ( earnmonth varchar2(6), -- 打工月份 area varchar2(20), -- 打工地区 sno varchar2(10), -- 打工者编号 sname varchar2(20), -- 打工者姓名 times int, -- 本月打工次

ORACLE统计分析函数

本文讲述Oracle分析函数用法,首先建库: Sql代码   create table earnings -- 打工赚钱表 ( earnmonth varchar2(6), -- 打工月份 area varchar2(20), -- 打工地区 sno varchar2(10), -- 打工者编号 sname varchar2(20), -- 打工者姓名 times int, -- 本月打工次数 singleincome number(10,2), -- 每次赚多少钱 personincome n

Binder学习笔记(二)——defaultServiceManager()返回了什么?

不管是客户端还是服务端,头部都要先调用 sp < IServiceManager > sm = defaultServiceManager(); defaultServiceManager()都干了什么,它返回的是什么实例呢? 该函数定义在frameworks/native/libs/binder/IserviceManager.cpp:33 sp<IServiceManager> defaultServiceManager() { if (gDefaultServiceManag

Python基础day10

本节主要内容:1. 函数参数--动态传参2. 名称空间, 局部名称空间, 全局名称空间, 作用域, 加载顺序.3. 函数的嵌套4. gloabal, nonlocal关键字一. 函数参数--动态传参之前我们说过了传参, 如果我们需要给一个函数传参, 而参数又是不确定的. 或者我给一个函数传很多参数, 我的形参就要写很多, 很麻烦, 怎么办呢. 我们可以考虑使用动态参数.形参的第三种: 动态参数动态参数分成两种:1. 动态接收位置参数首先我们先回顾一下位置参数, 位置参数, 按照位置进行传参 de