GESP2025年6月认证C++三级( 第三部分编程题(1)奇偶校验)

参考程序1

cpp 复制代码
#include <cstdio>       // 提供 scanf 和 printf 的头文件
using namespace std;

int n, v;               // n 表示数据个数,v 用于统计所有数据中 1 的个数

int main() {
    scanf("%d", &n);    // 输入数据个数
    for (int i = 1; i <= n; i++) {
        int c;
        scanf("%d", &c);    // 读取一个数据

        // 将该数据按位右移,并统计它的二进制表示中 1 的数量
        while (c) {
            v += c & 1;     // 如果最低位是 1,v 加一
            c >>= 1;        // 右移一位,准备处理下一位
        }
    }

    // 输出两个值:1的总数,和该总数的奇偶性(v&1 = 1 表示奇数,0 表示偶数)
    printf("%d %d\n", v, v & 1);

    return 0;
}

参考程序2

cpp 复制代码
#include <cstdio>
using namespace std;

int main() {
    int n, v = 0;        // v 表示统计所有二进制中 1 的个数
    scanf("%d", &n);     // 读入数据个数
    for (int i = 0; i < n; i++) {
        int c;
        scanf("%d", &c); // 读入一个整数
        while (c > 0) {
            if (c % 2 == 1)  // 如果最低位为 1,说明是奇数,统计 1
                v++;
            c = c / 2;       // 除以 2,去掉最低位
        }
    }
    printf("%d %d\n", v, v % 2);  // 输出总 1 的个数 和 校验码(奇数为 1,偶数为 0)
    return 0;
}
相关推荐
澈2075 小时前
深入浅出C++滑动窗口算法:原理、实现与实战应用详解
数据结构·c++·算法
A.A呐5 小时前
【C++第二十九章】IO流
开发语言·c++
ambition202425 小时前
从暴力搜索到理论最优:一道任务调度问题的完整算法演进历程
c语言·数据结构·c++·算法·贪心算法·深度优先
kebeiovo5 小时前
atomic原子操作实现无锁队列
服务器·c++
Yungoal5 小时前
常见 时间复杂度计算
c++·算法
6Hzlia5 小时前
【Hot 100 刷题计划】 LeetCode 48. 旋转图像 | C++ 矩阵变换题解
c++·leetcode·矩阵
Ricky_Theseus6 小时前
C++右值引用
java·开发语言·c++
吴梓穆7 小时前
UE5 c++ 常用方法
java·c++·ue5
云栖梦泽7 小时前
Linux内核与驱动:9.Linux 驱动 API 封装
linux·c++
Morwit7 小时前
【力扣hot100】 1. 两数之和
数据结构·c++·算法·leetcode·职场和发展