使用C++查询给定数组在索引范围内的按位或操作

使用c++查询给定数组在索引范围内的按位或操作

在本文中,我们给出了一个整数数组。我们的任务是找到给定范围内所有数字的按位或,例如,

Input: arr[] = {1, 3, 1, 2, 3, 4}, q[] = {{0, 1}, {3, 5}}Output:371 OR 3 = 32 OR 3 OR 4 = 7Input: arr[] = {1, 2, 3, 4, 5}, q[] = {{0, 4}, {1, 3}}Output:77

登录后复制

在给定的问题中,我们将使用强力方法来解决它,然后检查它是否可以适用于更高的约束。如果没有,那么我们将优化我们的方法以适应更高的约束。

暴力方法

在这种方法中,我们只需遍历每个范围并计算按位或该范围内的所有数字并打印我们的答案。

示例

#include using namespace std;int main() {   int arr[] = { 7, 5, 3, 5, 2, 3 };   int n = sizeof(arr) / sizeof(int); // size of our array   int queries[][2] = { { 1, 3 }, { 4, 5 } }; // given queries   int q = sizeof(queries) / sizeof(queries[0]); // number of queries   for(int i = 0; i 

输出

73

登录后复制

这种方法的时间复杂度为 O(N*Q),其中 N 是数组的大小,Q 是现在的查询数量,如您所见,这种复杂性不适用于更高的约束,所以现在我们将优化我们的方法,使其也适用于更高的约束。

立即学习“C++免费学习笔记(深入)”;

高效方法

在这种方法中,我们将计算前缀位数,然后检查是否数字有一个特定的位集。如果是,那么我们将这一点放入答案中;否则,我们保留这一点。

示例

#include using namespace std;#define bitt 32#define MAX (int)10e5int prefixbits[bitt][MAX];void bitcount(int *arr, int n) { // making prefix counts   for (int j = 31; j >= 0; j--) {      prefixbits[j][0] = ((arr[0] >> j) & 1);      for (int i = 1; i 

输出

73

登录后复制

此方法的时间复杂度为 O(N),其中 N 是数组的大小,因此此方法可以适用于更高的约束。

说明上面的代码

在这种方法中,我们计算前缀位数并存储它。现在我们计算一个查询,我们遍历该前缀计数并删除 l-1 的位计数,这样我们就有 [l, r] 范围内数字的位计数,因为我们知道如果在任何数字中设置了一个位因此,如果您将其与任何其他数字进行按位或,则该位将保持设置状态,因此使用按位或的此属性,我们检查位计数是否不为零,这意味着范围内存在具有设置位的数字,因此我们设置该位答案并继续循环,最后打印答案。

结论

本文解决了计算索引范围 [L, R] 中按位或的查询的问题给定的数组。我们还学习了解决这个问题的C++程序以及解决这个问题的完整方法(正常且高效)。我们可以用其他语言比如C、java、python等语言来编写同样的程序。我们希望这篇文章对您有所帮助。

以上就是使用C++查询给定数组在索引范围内的按位或操作的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2580632.html

(0)
上一篇 2025年3月6日 13:47:41
下一篇 2025年2月22日 17:29:29

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 检查是否可以通过交换字符使数组中的所有字符串相同

    在本文中,我们将探讨通过交换字符来检查数组中的所有字符串是否相同的问题。我们将首先理解问题陈述,然后研究解决该问题的简单和有效的方法,以及它们各自的算法和时间复杂度。最后,我们将用 C++ 实现该解决方案。 问题陈述 给定一个字符串数组,确…

    2025年3月6日
    200
  • 如何在C语言中清除控制台?

    有几种方法可以清除控制台或输出屏幕,其中之一是clrscr()函数。它在调用函数时清除屏幕。它在“conio.h”头文件中声明。还有一些其他方法,如system(“cls”)和system(“clear&…

    2025年3月6日
    200
  • 在C语言中,空指针是什么?

    它是一个指针,可以保存任何数据类型变量的地址(或)可以指向任何数据类型变量。 声明 void指针的声明如下所示 − void *pointername; 登录后复制 例如 − void *vp; 访问 − 通过指针访问变量的值时使用类型转换…

    2025年3月6日
    200
  • C语言中的快速排序是什么?

    由于其相对于其他排序算法的普及性和受欢迎程度,快速排序是一种经常使用的排序算法。然后,它将数组分为两组,一组包含小于所选主元的元素,另一组包含大于主元的元素。之后,算法对每个分区重复此过程,直到整个数组排序完毕。 任何需要排序的情况都可以从…

    2025年3月6日
    200
  • C语言return的用法详解

    C语言return的用法有:1、对于返回值类型为void的函数,可以使用return语句来提前结束函数的执行;2、对于返回值类型不为void的函数,return语句的作用是将函数的执行结果返回给调用者;3、提前结束函数的执行,在函数内部,我…

    2025年3月6日
    200
  • C语言undeclared identifier错误怎么办

    “undeclared identifier” 错误在C语言中通常意味着你正在尝试使用一个未声明的变量、函数或其他标识符。解决办法:1、检查拼写和大小写;2、检查声明;3、包含必要的头文件;4、检查作用域;5、检查链…

    2025年3月6日
    200
  • c语言有哪些编程软件

    常见的编程软件:1、Code::Blocks;2、Dev-C++;3、Eclipse;4、Visual Studio;5、Xcode;6、Sublime Text;7、Atom;8、Vim;9、Emacs;10、CLion。详细介绍:1、C…

    2025年3月6日
    200
  • 编写C语言中的指数函数表达式

    C语言中如何写指数函数表达式 指数函数是高等数学中的一个重要函数,它可以用于解决各种实际问题,如物理学中的指数增长和衰减、经济学模型中的利率计算等。在C语言中,我们可以使用数学库函数和自定义函数来实现指数函数表达式的计算。 一、使用数学库函…

    2025年3月6日
    200
  • C语言程序设计概述:从初学到专家

    C语言程序设计简介:从入门到精通 随着科技的快速发展和计算机的普及,编程已经成为一项重要的技能。而在各种编程语言中,C语言是最基础也是最重要的一门语言。无论是从事软件开发、嵌入式系统还是进行科学计算,掌握C语言都是必备的。本文将从C语言的基…

    2025年3月6日
    200
  • 深入了解C语言中scanf函数的输入格式控制

    透彻理解C语言中scanf函数的输入格式控制,需要具体代码示例 在C语言中,scanf函数是一个常用的输入函数,它允许我们从用户输入中读取数据,并将其存储在变量中。为了更好地控制输入的格式,scanf函数提供了输入格式控制符,通过这些控制符…

    2025年3月6日
    200

发表回复

登录后才能评论