C语言在线运行

版本:
运行结果
教程手册
代码仓库
极速运行
终端运行
图形+终端

                        
以下是用户最新保存的代码
2021年程序设计题4 发布于:2023-12-01 22:12 计数排序算法 发布于:2023-12-01 17:34 DGUSII 校验码 发布于:2023-12-01 15:44 数组添加头部字节 发布于:2023-12-01 14:00 创建函数调用 发布于:2023-11-30 17:33 一个数各位数字之和 发布于:2023-11-30 00:40 计数排序实现 发布于:2023-11-29 21:25 计数排序(基于比较) 发布于:2023-11-29 19:58 计数排序算法 发布于:2023-11-29 19:58 计数排序额 发布于:2023-11-29 20:28 计算日期 的程序 发布于:2023-12-01 16:35 堆排序实验 发布于:2023-11-29 17:58 这个是堆排序算法 发布于:2023-11-29 16:51 堆排序实现 发布于:2023-11-29 14:07 线性计数排序 发布于:2023-11-29 10:06 统计排序(非线性) 发布于:2023-11-29 09:28 堆排序C语言 发布于:2023-11-29 08:54 堆排序算法 发布于:2023-11-28 23:59 堆排序算法实验 发布于:2023-11-28 23:33 堆排序使用c语言 发布于:2023-11-28 23:04 堆排序算法 发布于:2023-11-28 20:47 堆排序。。 发布于:2023-11-28 19:13 堆排序。。 发布于:2023-11-28 19:11 堆排序实验 发布于:2023-11-28 19:08 计数排序算法 发布于:2023-11-28 16:51 计数排序算法 发布于:2023-11-28 16:37 线性计数排序算法 发布于:2023-11-29 13:45 计数排序算法 发布于:2023-11-28 16:30 计数排序算法 发布于:2023-11-28 16:30 计数排序算法 发布于:2023-11-28 16:28 计数排序。 发布于:2023-11-28 16:36 计数排序算法 发布于:2023-11-28 16:27 实现线性计数排序 发布于:2023-11-28 16:46 # 镁光B57T TLC地址转换为SLC地址 发布于:2023-11-28 16:18 第十一章:计数排序 发布于:2023-11-28 19:16 计数排序算法 发布于:2023-11-28 16:35 实现计数排序 发布于:2023-11-28 15:33 C语言fprintf与vfprintf用法示例(包含__FUNCTION__的使用) 发布于:2023-11-29 15:04 堆排序算法 发布于:2023-11-28 00:08 堆排序算法 发布于:2023-11-27 23:47 || and && 发布于:2023-11-27 23:29 堆排序实现 发布于:2023-11-27 23:12 堆排序算法 发布于:2023-11-27 23:11 自低向上堆排序 发布于:2023-11-27 23:04 堆排序算法。。 发布于:2023-11-27 22:38 堆排序的实现 发布于:2023-11-27 21:50 堆排序。。 发布于:2023-11-27 20:55 堆排序代码 发布于:2023-11-27 20:39 超级堆排序 发布于:2023-11-27 20:08 堆排序实验 发布于:2023-11-27 20:01 [更多]
显示目录

位运算符



位运算符

位运算符作用于位,并逐位执行操作。&、 | 和 ^ 的真值表如下所示:

p q p & q p丨q p ^ q
0 0 0 0 0
0 1 0 1 1
1 1 1 1 0
1 0 0 1 1

假设如果 A = 60,且 B = 13,现在以二进制格式表示,它们如下所示:

A = 0011 1100

B = 0000 1101

-----------------

A&B = 0000 1100

A|B = 0011 1101

A^B = 0011 0001

~A = 1100 0011

下表显示了 C 语言支持的位运算符。假设变量 A 的值为 60,变量 B 的值为 13,则:

运算符 描述 实例
& 按位与操作,按二进制位进行“与”运算。运算规则: 0&0=0; 0&1=0; 1&0=0; 1&1=1; (A & B) 将得到 12,即为 0000 1100
| 按位或运算符,按二进制位进行“或”运算。 运算规则:0丨0=0; 0丨1=1; 1丨0=1; 1丨1=1; (A丨B) 将得到 61,即为 0011 1101
^ 异或运算符,按二进制位进行“异或”运算。运算规则:0^0=0; 0^1=1; 1^0=1; 1^1=0 (A ^ B) 将得到 49,即为 0011 0001
~ 取反运算符,按二进制位进行“取反”运算。运算规则:~1=0 ~0=1; (~A ) 将得到 -61,即为 1100 0011,2 的补码形式,带符号的二进制数。
<< 二进制左移运算符。左操作数的值向左移动右操作数指定的位数(左边的二进制位丢弃,右边补0)。 A << 2 将得到 240,即为 1111 0000
>> 二进制右移运算符。左操作数的值向右移动右操作数指定的位数(正数左补0,负数左补1,右边丢弃)。 A >> 2 将得到 15,即为 0000 1111

实例

请看下面的实例,了解 C 语言中所有可用的位运算符:

    #include <stdio.h>

    int main()
    {

       unsigned int a = 60; /* 60 = 0011 1100 */  
       unsigned int b = 13; /* 13 = 0000 1101 */
       int c = 0;           

       c = a & b;       /* 12 = 0000 1100 */ 
       printf("Line 1 - c 的值是 %d\n", c );

       c = a | b;       /* 61 = 0011 1101 */
       printf("Line 2 - c 的值是 %d\n", c );

       c = a ^ b;       /* 49 = 0011 0001 */
       printf("Line 3 - c 的值是 %d\n", c );

       c = ~a;          /*-61 = 1100 0011 */
       printf("Line 4 - c 的值是 %d\n", c );

       c = a << 2;     /* 240 = 1111 0000 */
       printf("Line 5 - c 的值是 %d\n", c );

       c = a >> 2;     /* 15 = 0000 1111 */
       printf("Line 6 - c 的值是 %d\n", c );
    }

当上面的代码被编译和执行时,它会产生下列结果:

Line 1 - c 的值是 12
Line 2 - c 的值是 61
Line 3 - c 的值是 49
Line 4 - c 的值是 -61
Line 5 - c 的值是 240
Line 6 - c 的值是 15
由JSRUN为你提供的C语言在线运行、在线编译工具
        JSRUN提供的C语言 在线运行,C语言 在线运行工具,基于linux操作系统环境提供线上编译和线上运行,具有运行快速,运行结果与常用开发、生产环境保持一致的特点。