zoukankan      html  css  js  c++  java
  • 按位与、按位或、按位异或、左移、右移运算符的简单介绍(部分二进制运算符的简单介绍)

    C语言中集中二进制运算符的介绍

    1.  按位或:|

    将两个二进制的数字对应位数进行比较,只要有一个为1,则结果中对应的位数为1.比如以:十进制的3和十进制的2为例:

      3的二进制   0000 00 11

     2 的二进制    0000 00 10,

    两个数 末位的数字是1和0,结果就为1;倒数第二位都为1;所以结果为1;其余位数都为0;所以结果中其余位数也为0;

    所以3|2结果就为:   0000 0011;转换为二进制就是3.

    2.  按位与:&

    将两个二进制的数字对应位数进行比较,如果两个数都为1,则结果中对应的位数为1.否则为0;比如以:十进制的3和十进制的2为例:

     3的二进制  0000 00 11

     2 的二进制    0000 00 10,

    两个数末位的数字是1和0,结果就为0;倒数第二位都为1;所以结果为1;其余位数都为0;所以结果中其余位数也为0;

    所以3&2结果就为:   0000 0010;转换为二进制就是2.

    3.  按位异或:^

    将两个二进制的数字对应位数进行比较,如果两个数相同则结果中对应的位数为1.否则为0;以十进制的3和十进制的2为例:

     3的二进制  0000 00 11

     2 的二进制    0000 00 10,

    两个数末位的数字是1和0,结果就为1;倒数第二位都为1;所以结果为0;其余位数都为0;所以结果中其余位数也为0;

    所以32结果就为:   0000 0001;转换为二进制就是1

    4左移、右移运算符:

    左移 运算符:

    将数据中所有位数字向左移一位,左侧溢出的数据忽略。右侧空白处补零,如下图:


    右移 运算符:

    将数据中所有位数字向右移一位,右侧溢出的数据忽略。左侧空白处补符号位(正数补0,负数补1),如下图:

    5.按位取反:~

    零一互换:~0=1;~1=0;

    按位取反比较简单,工作中也不常用这里就不详细介绍了。


    版权声明:本文为博主原创文章,未经博主允许不得转载。

  • 相关阅读:
    HDU3247 Resource Archiver(AC自动机+BFS+DP)
    POJ2486 Apple Tree(树形DP)
    POJ1699 Best Sequence(AC自动机+状压DP)
    SPOJ287 Smart Network Administrator(最大流)
    POJ3189 Steady Cow Assignment(最大流)
    ZOJ2332 Gems(最大流)
    COGS731 [网络流24题] 最长递增子序列(最大流)
    POJ1947 Rebuilding Roads(树形DP)
    POJ1135 Domino Effect(SPFA)
    SPOJ962 Intergalactic Map(最大流)
  • 原文地址:https://www.cnblogs.com/wahy/p/4817257.html
Copyright © 2011-2022 走看看