迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > C语言 >

C 语言中的位比较

作者:迹忆客 最近更新:2023/03/27 浏览次数:

本文将介绍几种比较 C 语言中位的方法。


在 C 语言中使用按位 XOR 和 AND 操作实现按位比较的自定义函数

通常,位比较需要访问单个位值并进行所需的操作,例如使用 unionstruct 关键字实现位字段。但是,按位运算提供了一种比较数字中指定位的更有效方法。在这种情况下,我们将实现一个适用于 u_int32_t 类型的单独函数,该函数必须具有 32 位宽度。

示例程序将三个整数用作命令行参数,其中前两个是要比较的数字,而第三个整数指定第 n 位。注意,我们使用 strtol 转换 argv 元素,因此在以 u_int32_t 类型存储返回值时会损失一些精度。compareBits 函数声明两个存储中间值的局部变量-masktmp。我们通过将 1 向左移动 nth - 1 个位置来设置掩码中的第 n 个位。然后,对两个用户输入数字进行 XOR 运算,以得到每个位置的位差,并在结果中表示不同的值。最后,我们需要从第 n 个位置提取该位,并检查该值是否为 0

#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <stdbool.h>

bool compareBits(u_int32_t n1, u_int32_t n2, u_int32_t nth) {
    u_int32_t mask, tmp;

    mask = 1 << (nth - 1);
    tmp = n1 ^ n2;

    if ((tmp & mask) == 0)
        return true;
    else
        return false;
}

int main(int argc, char *argv[]) {
    u_int32_t num1, num2, bit;

    if (argc != 4) {
        fprintf(stderr, "Usage: %s integer1 integer2 nth_bit \n", argv[0]);
        exit(EXIT_FAILURE);
    }

    num1 = strtol(argv[1], NULL, 0);
    num2 = strtol(argv[2], NULL, 0);
    bit = strtol(argv[3], NULL, 0);

    compareBits(num1, num2, bit) ? printf("bits equal!\n") : printf("bits not equal!\n");

    exit(EXIT_SUCCESS);
}

样本文件格式:

./program 1234 1231 1

输入文件格式:

bits not equal!

例如,整数 12341231 分别用二进制表示为 0000000000000000000001001001101001000000000000000000000010011001111。因此,对这两个值进行 XOR 运算得到二进制表示形式 00000000000000000000000000011101,最后将其与掩码 0000000000000000000000000000001010 进行 AND 运算以提取单个位的位置值。如果结果全为零,则表示比较的位相等;否则,结果相反。

但是,我们也可以缩短 compareBits 函数,并将 XOR/AND 操作移至 return 语句,如以下示例代码所示。注意,该函数返回与按位 XOR/AND 运算相反的逻辑,因为我们在调用函数中使用 ? :三元语句输出相应的消息。

#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <stdbool.h>

bool compareBits(u_int32_t n1, u_int32_t n2, u_int32_t nth) {
    u_int32_t mask;

    mask = 1 << (nth - 1);

    return !((n1 ^ n2) & mask);
}

int main(int argc, char *argv[]) {
    u_int32_t num1, num2, bit;

    if (argc != 4) {
        fprintf(stderr, "Usage: %s integer1 integer2 nth_bit \n", argv[0]);
        exit(EXIT_FAILURE);
    }

    num1 = strtol(argv[1], NULL, 0);
    num2 = strtol(argv[2], NULL, 0);
    bit = strtol(argv[3], NULL, 0);

    compareBits(num1, num2, bit) ? printf("bits equal!\n") : printf("bits not equal!\n");

    exit(EXIT_SUCCESS);
}

示例文件格式:

./program 1234 1231 2

输入文件格式:

bits equal!

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

在 C 语言中使用 typedef enum

发布时间:2023/05/07 浏览次数:181 分类:C语言

本文介绍了如何在 C 语言中使用 typedef enum。使用 enum 在 C 语言中定义命名整数常量 enum 关键字定义了一种叫做枚举的特殊类型。

C 语言中的静态变量

发布时间:2023/05/07 浏览次数:151 分类:C语言

本文介绍了如何在 C 语言中使用静态变量。在 C 语言中使用 static 变量在函数调用之间保存变量值

C 语言中生成随机数

发布时间:2023/05/07 浏览次数:64 分类:C语言

本文演示了如何在 C 语言中生成随机数。使用 rand 和 srand 函数在 C 语言中生成随机数

C 语言中的 i++ 与++i

发布时间:2023/05/07 浏览次数:83 分类:C语言

本文演示了如何在 C 语言中使用前缀增量与后缀增量运算符。C 语言中++i 和 i++ 记号的主要区别

C 语言中获取当前工作目录

发布时间:2023/05/07 浏览次数:182 分类:C语言

本文演示了如何在 C 语言中获取当前工作目录。使用 getcwd 函数获取当前工作目录的方法

C 语言中的位掩码

发布时间:2023/05/07 浏览次数:126 分类:C语言

本文介绍了如何在 C 语言中使用位掩码。使用 struct 关键字在 C 语言中定义位掩码数据

C 语言中的排序函数

发布时间:2023/05/07 浏览次数:181 分类:C语言

本文演示了如何在 C 语言中使用标准库排序函数。使用 qsort 函数对 C 语言中的整数数组进行排序

C 语言中的 extern 关键字

发布时间:2023/05/07 浏览次数:114 分类:C语言

本文介绍了如何在 C 语言中使用 extern 关键字。C 语言中使用 extern 关键字来声明一个在其他文件中定义的变量

C 语言中的 #ifndef

发布时间:2023/05/07 浏览次数:186 分类:C语言

本文介绍了如何在 C 语言中使用 ifndef。在 C 语言中使用 ifndef 保护头文件不被多次包含 C 语言中的头文件用于定义同名源文件中实现的函数的接口。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便