在C++中,最大化具有零XOR的子数组的数量
我们得到一个包含整数值的数组 Arr[]。目标是找到 XOR 为 0 的子数组的最大数量。任何子数组的位都可以交换任意次数。
注意:- 118
为了通过交换位使任意子数组的异或为0,必须满足两个条件:-
- 如果从左到右范围内的设置位数为偶数。
对于任何给定范围的位数总和
让我们看看各种输入输出场景 -
In −Arr[] = { 1,2,5,4 }
Out −
仅满足第一个条件的子数组:4
满足两个条件的子数组:3
In − Arr[] = { 3,7,2,9 }
Out −
仅满足第一个条件的子数组条件:6
满足两个条件的子数组:3
下面的程序中使用的方法如下 -
在这种方法中,我们观察到为了使通过交换位将任何子数组的 XOR 为 0,必须满足两个条件:- 如果从左到右范围内的设置位数为偶数或对于任何给定范围的位总和
获取输入数组Arr[]并计算其长度。
函数removeSubarr(int arr[], int len) 返回不满足条件 2 的子数组的个数。
将初始计数设为 0。
迭代数组使用 for 循环并采用变量 sum 和 maxVal。
-
采用另一个 for 循环在 60 个子数组的范围内进行迭代,因为超过 60 个子数组,条件 2 永远不会为 false。
将元素添加到 sum 中,并在 maxVal 中取最大值。
如果 sum 为偶数且 2 * maxVal > sum,则将计数作为条件 2 递增不满足。
两个循环结束时都返回 count。
函数 findSubarrays(int arr1[], int len1) 接受一个输入数组及其长度,并返回满足上述两个条件的子数组的数量。
采用前缀数组来计算仅满足条件 1 的子数组的数量.
使用for循环遍历数组并设置每个元素 __builtin_popcountll(arr1[i]) 这是其中设置的位数。
使用 for 循环填充前缀数组并设置 prefix[i] = prefix[i] + prefix [i - 1] 除第一个元素外的位置。
计算前缀数组中的奇数和偶数值。
设置 tmp1 = ( oddcount * (oddcount-1) )/2 和 tmp2= ( Evencount * (evencount-1) )/2 并将结果作为两者之和。
结果将是仅满足条件 1 的子数组之和。
打印结果。
现在用 result=result 更新结果 - removeSubarr( arr1, len1)。
现在结果包含满足这两个条件的子数组。
-
再次打印结果。
示例
#include <bits/stdc++.h> using namespace std; // Function to count subarrays not satisfying condition 2 int removeSubarr(int arr[], int len){ int count = 0; for (int i = 0; i < len; i++){ int sum = 0; int maxVal = 0; for (int j = i; j < min(len, i + 60); j++){ sum = sum + arr[j]; maxVal = arr[j] > maxVal ? arr[j]: maxVal; if (sum % 2 == 0){ if( 2 * maxVal > sum) { count++; } } } } return count; } int findSubarrays(int arr1[], int len1){ int prefix[len1]; int oddcount, evencount; int result; for (int i = 0; i < len1; i++) { arr1[i] = __builtin_popcountll(arr1[i]); } for (int i = 0; i < len1; i++){ prefix[i] = arr1[i]; if (i != 0) { prefix[i] = prefix[i] + prefix[i - 1]; } } oddcount = evencount = 0; for (int i = 0; i < len1; i++){ if (prefix[i] % 2 == 0) { evencount = evencount +1; } else { oddcount = oddcount +1; } } evencount++; int tmp1= ( oddcount * (oddcount-1) )/2; int tmp2= ( evencount * (evencount-1) )/2; result = tmp1+tmp2; cout << "Subarrays satisfying only 1st condition : "<<result << endl; cout << "Subarrays satisfying both condition : "; result = result - removeSubarr(arr1, len1); return result; } int main() { int Arr[] = { 1,2,5,4 }; int length = sizeof(Arr) / sizeof(Arr[0]); cout << findSubarrays(Arr, length); return 0; }
输出
如果我们运行上面的代码,它将生成以下输出
Subarrays satisfying only 1st condition : 4 Subarrays satisfying both condition : 3
以上是在C++中,最大化具有零XOR的子数组的数量的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

我们有两个整数数组,一个具有计算的元素,另一个具有分割数组以生成子集所需的分割点,我们必须计算每个分割中每个子集的总和并返回最大子集让我们通过示例来理解:-输入−intarr[]=intarr[]={9,4,5,6,7}intsplitPoints[]={0,2,3,1};输出−每次分割后的最大子数组和[22,13,9,9]解释−这里我们根据数组的分割点来分解数组,并在每次分割后获得最大子集和第一次分割后→{9}和{4,5,6,7}>>最大子数组总和为-22第二次分割后→{9},{4

在本文中,我们将使用C++解决寻找最大值和最小值相同的子数组数量的问题。以下是该问题的示例−Input:array={2,3,6,6,2,4,4,4}Output:12Explanation:{2},{3},{6},{6},{2},{4},{4},{4},{6,6},{4,4},{4,4}and{4,4,4}arethesubarrayswhichcanbeformedwithmaximumandminimumelementsame.Input:array={3,3,1,5,

我们有5个整数变量Num,P1,P2,profit_P1,profit_P2,并且任务是最大化利润,并从范围[1,Num]中的所有自然数中选择。这里的方法是,如果一个正数可以被P1整除,利润增加profit_P1,同样,如果范围内的数字可以被P2整除,利润增加profit_P2。此外,正整数的利润最多只能添加一次。让我们通过例子来理解:输入-intnum=4,P1=6,P2=2,profit_P1=8,profit_P2=2;输出-最大化所有人的总利润X4解释-这里的数字范围是1到4([1,Nu

在这篇文章中,我们将使用C++找出具有小于K的和的子数组的数量。在这个问题中,我们有一个数组arr[]和一个整数K。现在我们需要找出和小于K的子数组。以下是示例−Input:arr[]={1,11,2,3,15}K=10Output:4{1},{2},{3}and{2,3}寻找解决方案的方法现在我们将使用两种不同的方法来解决给定的问题-暴力破解在这种方法中,我们将迭代遍历所有子数组并计算它们的总和,如果总和小于k,则与k进行比较,以增加我们的答案。示例#include<

我们得到一个包含整数值的数组Arr[]。目标是找到XOR为0的子数组的最大数量。任何子数组的位都可以交换任意次数。注意:-1

给定两个相同长度的二进制字符串str1和str2,我们必须通过从给定的相同长度的字符串中选择子字符串来最大化给定的函数值。给定的函数是这样的-fun(str1,str2)=(len(子字符串))/(2^xor(sub1,sub2))。这里,len(substring)是第一个子字符串的长度,而xor(sub1,sub2)是给定子字符串的异或,因为它们是二进制字符串,所以这是可能的。示例Input1:stringstr1=10110&stringstr2=11101Output:3说明我们

数组是一组相似的数据集合,以连续的方式存储在相邻的内存位置上。通过将偏移值定义为数据库的特定基值,可以更容易地评估每个元素的特定位置。该特定索引的基值为零,偏移值是两个特定索引之间的差值。子数组是特定数组的一部分,可以定义为一组变量,具有多个值的标签。最长的子数组指的是数组中所有元素都大于K的数组。这里最大和子数组的和为-给定数据集中的少于等于给定的数据集。给定数据集中的少于要找到最长子数组的长度,我们只需要找出特定子数组中1的总数。注意:计数应该大于零的计数。最大公约数是一种数学现象,在其中我

子数组是数组的连续部分。例如,我们考虑一个数组[5,6,7,8],那么有十个非空子数组,如(5),(6),(7),(8),(5,6),(6,7)、(7,8)、(5,6,7)、(6,7,8)和(5,6,7,8)。在本指南中,我们将解释在C++中查找所有可能的信息来查找具有奇数和的子数组的数量。为了找到奇数和的子数组的数量,我们可以使用不同的方法,所以这里是一个简单的例子-Input:array={9,8,7,6,5}Output:9Explanation:Sumofsubarray-{9}=9{7
