使用C++,将以下内容翻译为中文:在给定数组的索引范围内进行按位与的查询

使用C++,将以下内容翻译为中文:在给定数组的索引范围内进行按位与的查询

在本文中,我们给出了一个问题,其中给定一个整数数组,我们的任务是找到给定范围的按位与,例如 7minus;

  1. Input: arr[ ] = {1, 3, 1, 2, 32, 3, 3, 4, 4}, q[ ] = {{0, 1}, {3, 5}}Output:10 01 AND 31 = 123 AND 34 AND 4 = 00Input: arr[ ] = {1, 2, 3, 4, 510, 10 , 12, 16, 8}, q[ ] = {{0, 42}, {1, 33, 4}}Output:0 80

登录后复制

我们将首先应用暴力方法并检查其时间复杂度。如果我们的时间复杂度不够好,我们会尝试开发更好的方法。

暴力方法

在给定的方法中,我们将遍历给定的范围并找到我们的方法回答并打印。

示例

  1. #include using namespace std;int main() {   int ARR[] = { 10, 10 , 12, 16, 8 };   int n = sizeof(ARR) / sizeof(int); // size of our array   int queries[][2] = { {0, 2}, {3, 4} }; // given queries   int q = sizeof(queries) / sizeof(queries[0]); // number of queries   for(int i = 0; i

    输出

    80
  2. 登录后复制

  3. 在这种方法中,我们对每个查询的范围运行一个循环,并按位打印它们的集合,因此我们程序的整体复杂性变为O(N*Q),其中 N 是数组的大小,Q 是我们现在的查询数量,您可以看到这种复杂性不适合更高的约束,因此我们将针对此问题提出更快的方法。

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

  5. 高效方法 h2>

  6. 在这个问题中,我们预先计算数组的前缀位数,通过检查给定范围内设置位的贡献来计算给定范围的按位与。

  7. 示例

  8. #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 

    输出

    20
  9. 登录后复制

  10. 在这种方法中,我们使用恒定的时间来计算查询,从而将时间复杂度从 O(N*Q) 大大降低到 O(N),其中 N 是现在给定数组的大小。该程序也可以适用于更高的约束。

  11. 上述代码的说明

  12. 在这种方法中,我们计算所有前缀位数并将其存储在索引中。现在,当我们计算查询时,我们只需要检查某个位的计数是否与范围中存在的元素数量相同。如果是,我们在 x 中将此位设置为 1,如果否,我们保留该位,就好像给定范围中存在的任何数字都具有该位 0,因此该位的整个按位 AND 将为零,这就是如何我们正在计算按位与。

  13. 结论

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

  15. 以上就是使用C++,将以下内容翻译为中文:在给定数组的索引范围内进行按位与的查询的详细内容,更多请关注【创想鸟】其它相关文章!

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

点点赞赏,手留余香

给TA打赏
共0人
还没有人赞赏,快来当第一个赞赏的人吧!
    编程技术

    打印N行数字,使得每对数字之间的最大公约数为K

    2025-3-6 15:08:20

    编程技术

    C程序:查找字符串中字符的最小出现次数

    2025-3-6 15:08:29

    0 条回复 A文章作者 M管理员
    欢迎您,新朋友,感谢参与互动!
      暂无讨论,说说你的看法吧
    个人中心
    购物车
    优惠劵
    今日签到
    私信列表
    搜索