5373. 中等计算

文章目录

Question

给定一个长度为 n

的非负整数序列 a1,a2,...,an

对于 1≤i≤n

,有 bi=ai⊕(imod1)⊕(imod2)⊕...⊕(imodn)

请你计算并输出 b1⊕b2⊕...⊕bn

的值。

表示按位异或。

输入格式

第一行包含整数 n

第二行包含 n

个整数 a1,a2,...,an

输出格式

一个整数,表示 b1⊕b2⊕...⊕bn

的值。

数据范围

前 3

个测试点满足 1≤n≤3

所有测试点满足 1≤n≤106

,0≤ai≤2×109

输入样例:

3

1 2 3

输出样例:

3

Ideas

Code

cpp 复制代码
// 时间复杂度需要控制在O(N)或者O(nlgn)
// 将计算结果的矩阵写出来,尝试找规律,发现竖着有规律
// 规律为,第一列取模结果均为0000,第二列为0101,第三列为0120...以此循环
// 根据异或运算的性质(交换律、X^X=0)可以得出如果循环序列循环k次,k为偶数就等于0
// 所以只需要判断k是否奇数,还需要处理循环序列的最后的部分,最后一个元素为n%i(i为列号)
// 可以预处理一个前缀和数组s[i],表示1^2...^n; s[0] = 0
#include <iostream>
#include <cstring>
#include <algorithm>

using namespace std;

const int N = 1000010;

int n;
int s[N];

int main()
{
    scanf("%d", &n);
    for (int i = 1; i <= n; i ++ ) s[i] = s[i - 1] ^ i;

    int res = 0;
    for (int i = 0; i < n; i ++ )
    {
        int a;
        scanf("%d", &a);
        res ^= a;
    }

    for (int i = 1; i <= n; i ++ )
    {
        int k = n / i; 
        if (k & 1) res ^= s[i - 1];
        res ^= s[n % i];
    }

    printf("%d\n", res);
    return 0;
}
相关推荐
谷雨不太卷4 小时前
进程的状态码
java·前端·算法
顾温4 小时前
default——C#/C++
java·c++·c#
凉茶钱4 小时前
【c语言】动态内存管理:malloc,calloc,realloc,柔性数组
c语言·c++·vscode·柔性数组
脏脏a4 小时前
【C++模版】泛型编程:代码复用的终极利器
开发语言·c++·c++模版
island13144 小时前
【C++仿Muduo库#3】Server 服务器模块实现上
服务器·开发语言·c++
散峰而望4 小时前
【算法竞赛】C/C++ 的输入输出你真的玩会了吗?
c语言·开发语言·数据结构·c++·算法·github
小龙报4 小时前
【C语言】内存里的 “数字变形记”:整数三码、大小端与浮点数存储真相
c语言·开发语言·c++·创业创新·学习方法·visual studio
躺不平的理查德4 小时前
时间复杂度与空间复杂度备忘录
数据结构·算法
yaki_ya4 小时前
yaki-C语言:从概念基础到内存解析---数组(array)完全指南
java·c语言·算法
刃神太酷啦4 小时前
扒透 STL 底层!map/set 如何封装红黑树?迭代器逻辑 + 键值限制全手撕----《Hello C++ Wrold!》(23)--(C/C++)
java·c语言·javascript·数据结构·c++·算法·leetcode