蓝桥杯2023年第十四届省赛真题-异或和之和--题解

目录

蓝桥杯2023年第十四届省赛真题-异或和之和

题目描述

输入格式

输出格式

样例输入

样例输出

【代码实现】


大家觉得写得可以的话,可以加入QQ群907575059.

蓝桥杯2023年第十四届省赛真题-异或和之和

时间限制: 3s 内存限制: 320MB 提交: 241 解决: 66

题目描述

给定一个数组 Ai,分别求其每个子段的异或和,并求出它们的和。或者说,对于每组满足 1 ≤ L ≤ R ≤ n 的 L, R ,求出数组中第 L 至第 R 个元素的异或和。然后输出每组 L, R 得到的结果加起来的值。

输入格式

输入的第一行包含一个整数 n 。

第二行包含 n 个整数 Ai ,相邻整数之间使用一个空格分隔。

输出格式

输出一行包含一个整数表示答案。

样例输入

复制

复制代码
5
1 2 3 4 5

样例输出

复制

复制代码
39

【代码实现】

复制代码
package LQB;

import java.util.Scanner;

/**
 * @ProjectName: study3
 * @FileName: Ex5
 * @author:HWJ
 * @Data: 2023/9/18 20:35
 */
public class Ex5 {
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        int n = input.nextInt();
        int[] arr = new int[n];
        for (int i = 0; i < n; i++) {
            arr[i] = input.nextInt();
        }
        long res = 0;
        for (int i = 0; i < n; i++) {
            long sum = arr[i];
            res += sum;
            for (int j = i + 1; j < n; j++) {
                sum ^= arr[j];
                res += sum;
            }
        }
        System.out.println(res);
    }

}
相关推荐
2301_822376946 小时前
C++中的解释器模式
开发语言·c++·算法
xhbaitxl7 小时前
算法学习day31-贪心算法
学习·算法·贪心算法
爱学习的阿磊7 小时前
C++代码冗余消除
开发语言·c++·算法
YuTaoShao7 小时前
【LeetCode 每日一题】2976. 转换字符串的最小成本 I
算法·leetcode·职场和发展
蒟蒻的贤7 小时前
滑动窗口策略
算法
闪电麦坤957 小时前
Leecode热题100:矩阵置零(矩阵)
线性代数·算法·矩阵
浅念-7 小时前
C语言——双向链表
c语言·数据结构·c++·笔记·学习·算法·链表
Wh-Constelltion7 小时前
【PQ分解法潮流计算(matlab版)】
算法·matlab
只是懒得想了8 小时前
C++实现密码破解工具:从MD5暴力破解到现代哈希安全实践
c++·算法·安全·哈希算法
m0_736919108 小时前
模板编译期图算法
开发语言·c++·算法