📌  相关文章
📜  Javascript程序在K循环移位后将给定数组分成两半后使用按位或查找数组和

📅  最后修改于: 2022-05-13 01:56:06.813000             🧑  作者: Mango

Javascript程序在K循环移位后将给定数组分成两半后使用按位或查找数组和

给定一个长度为N数组 A[] ,其中 N 是偶数,任务是回答Q个独立查询,其中每个查询由一个正整数K组成,表示对数组执行的循环移位的次数,并找到元素的总和通过对分割后的数组执行按位或运算。
注意:每个查询都从原始数组开始。
例子:

天真的方法:
要解决上面提到的问题,最简单的方法是将数组的每个元素移动K % (N / 2) ,然后遍历数组来计算每个查询的两半的 OR。但是这种方法效率不高,因此可以进一步优化。
有效的方法:
为了优化上述方法,我们可以借助 Segment Tree 数据结构。

以下是解决问题的步骤:

  • 为原始数组A[]构造一个段树并分配一个变量,比如说i = K % (N / 2)
  • 然后对于每个查询,我们使用查找按位或的段树;即从末尾开始的 i 个元素的按位或第一个(N / 2) – i – 1 个元素的按位或。
  • 然后计算[(N / 2) – i, N – i – 1]范围内元素的按位或。
  • 将这两个结果相加以获得第 i 个查询的答案。

下面是上述方法的实现:

Javascript


输出:
238
230

时间复杂度: O(N + Q*logN)

辅助空间: O(4*MAX)

有关详细信息,请参阅完整的文章在 K 循环移位后将给定数组分成两半后使用按位或查找数组和!