C语言位操作方法有哪些-成都快上网建站

C语言位操作方法有哪些

本篇内容主要讲解“C语言位操作方法有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C语言位操作方法有哪些”吧!

创新互联公司服务项目包括奉节网站建设、奉节网站制作、奉节网页制作以及奉节网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,奉节网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到奉节省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!

位操作

        位操作是程序设计中对位模式按位或二进制数的一元和二元操作. 在许多古老的微处理器上, 位运算

比加减运算略快, 通常位运算比乘除法运算要快很多. 在现代架构中, 情况并非如此:位运算的运算速度通常

与加法运算相同(仍然快于乘法运算)。

 位运算符

     取反(~)是一元运算符, 对一个二进制数的每一位执行逻辑反操作。使数字1成为0, 0成为1。

      按位或(|) 处理两个长度相同的二进制数,两个相应的二进位中只要有一个为1,该位的结果值为1。

     按位异或(^)是对等长二进制模式按位或二进制数的每一位执行逻辑异按位或操作,操作的结果是如果某位不同则该位为1,否则该位为0。

       按位与(&)处理两个长度相同的二进制数,两个相应的二进位都为1,该位的结果值才为1,否则为0。

 移位

      移位是一个二元运算符,用来将一个二进制数中的每一位全部都向一个方向移动指定位,溢出的部分将被舍弃,而空缺的部分填入一定的值。在类C语言中,左移使用两个小于符号"<<"表示,右移使用两个大于符号">>"表示。

      逻辑移位(不管是左移位还是右移位) 都是空缺处补0。

       算术移位 要保证符号位的不改变(逻辑左移位补0, 逻辑右移位看符号位)。

        例如:110110011是-10110011前面的第一个1是符号位

                    那么110110011右移一位应该是111011001。

下面是一些位运算的简单编程题

  1. 不用额外变量交换两个整数的值

#include
using namespace std;

int fun1(int a,int b)
{
        int tmp=a-b;
        tmp>>=(sizeof(int)*4-1);
        if(tmp)
                return b;
        return a;
}
int main()
{
        int a=-134,b=98;
        cout<<"max:"<

2. 不用任何比较判断找出两个数中较大的数

#include
using namespace std;

void fun2(int &a,int &b)
{
        a=a+b;
        b=a-b;
        a=a-b;
}
int main()
{
        int a=-134,b=98;
        fun2(a,b);
        cout<<"a:"<

3. 整数的二进制表达式中的1的个数

#include
using namespace std;

int fun3(int a)
{
        int tmp,count=0;
        for(int i=1;i<32;a>>=1,++i)
        {
                if(a&1==1)
                        count++;
        }
        return count;
}
int main()
{        fun4();
        cout<

4. 给定一个整数数组ar, 其中只有一个数出现了奇数次数,其他的数都是偶数词,打印这个数。

#include
using namespace std;

int fun4(int *ar,int n)
{
        int tmp=0;
        for(int i=0;i

到此,相信大家对“C语言位操作方法有哪些”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


本文标题:C语言位操作方法有哪些
地址分享:http://kswjz.com/article/iihjhg.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流