当前位置: 首页 > 编程笔记 >

在数组中找到最大的d,使得C ++中的a + b + c = d

徐经武
2023-03-14
本文向大家介绍在数组中找到最大的d,使得C ++中的a + b + c = d,包括了在数组中找到最大的d,使得C ++中的a + b + c = d的使用技巧和注意事项,需要的朋友参考一下

假设我们有一组整数。我们必须找到一个数字“ d”,其中d = a + b + c,并且必须最大化(a + b + c),所有a,b,c和d都存在于集合中。该集合将至少容纳一个元素,最多可容纳1000个元素。每个元素将是一个有限数。如果集合为{2,3,5,7,12},则12为最大d。这可以表示为2 + 3 + 7

为了解决这个问题,我们可以使用哈希技术。我们将所有对(a + b)的和存储在哈希表中,然后遍历所有对(c,d)并在表中查找(d-c)是否存在。如果找到一个匹配项,请确保没有两个元素相同,并且没有将相同的元素视为两次。

示例

#include<iostream>
#include<unordered_map>
#include<climits>
using namespace std;
int findElementsInSet(int arr[], int n) {
   unordered_map<int, pair<int, int> > table;
   for (int i = 0; i < n - 1; i++)
      for (int j = i + 1; j < n; j++)
         table[arr[i] + arr[j]] = { i, j };
      int d = INT_MIN;
      for (int i = 0; i < n - 1; i++) {
         for (int j = i + 1; j < n; j++) {
            int abs_diff = abs(arr[i] - arr[j]);
            if (table.find(abs_diff) != table.end()) {
               pair<int, int> p = table[abs_diff];
               if (p.first != i && p.first != j && p.second != i && p.second != j) d = max(d, max(arr[i], arr[j]));
            }
         }
      }
   return d;
}
int main() {
   int arr[] = { 2, 3, 5, 7, 12 };
   int n = sizeof(arr) / sizeof(arr[0]);
   int res = findElementsInSet(arr, n);
   if (res == INT_MIN)
      cout << "Cannot find the value of d";
   else
      cout << "Max value of d is " << res;
}

输出结果

Max value of d is 12
 类似资料:
  • 任务给你一个排序的整数数组arr。它包含几个唯一的整数(负、正或零)。 您的任务是找到最大的d,使得a b c=d,其中a、b、c和d是arr的不同元素。如果没有找到这样的元素d,则返回null。 例子: 对于arr=[2,3,5,7,12],输出应该是12(这个数组正确传递了我的函数) 对于arr=[-100,-1,0,7,101],输出应该是0(这个不通过) 我可以进行正数检查,但我的函数因负

  • 本文向大家介绍在数组中找到四个元素a,b,c和d,以便在C ++中a + b = c + d,包括了在数组中找到四个元素a,b,c和d,以便在C ++中a + b = c + d的使用技巧和注意事项,需要的朋友参考一下 假设我们有一个整数列表。我们的任务是找到四个不同的整数,分别为(a,b)和(c,d)两对,这样a + b = c + d。如果有多个答案,则仅打印一个。假设数组元素像:A = [7

  • 本文向大家介绍在C ++中找到2 ^(2 ^ A)%B,包括了在C ++中找到2 ^(2 ^ A)%B的使用技巧和注意事项,需要的朋友参考一下 在本教程中,我们将编写一个程序来计算等式2 ^(2 ^ A)%B。 我们将使用递归函数找到方程的值。让我们看看解决问题的步骤。 编写一个带有2个参数A和B的递归函数。 如果A为1,则将4%B返回为2 ^(2 ^ 1)%B = 4%B. 否则用A-1和b递归

  • 本文向大家介绍找到将数字分为四部分的方法数量,以使C ++中的a = c和b = d,包括了找到将数字分为四部分的方法数量,以使C ++中的a = c和b = d的使用技巧和注意事项,需要的朋友参考一下 假设我们有一个数字n。我们必须找到多种方法将数字分为几部分(a,b,c和d),使得a = c,b = d。因此,如果数字为20,则输出将为4。如[1、1、9、9],[2、2、8、8],[3、3、7

  • 我想用一个算法实现最大子数组问题,该算法表现为(n log n): 查找最大相邻子数组,或数组中相邻元素的最大和。 假设:并非所有元素都是负数 我有一些工作的解决办法;问题在于重叠中心数组,而适当的索引表示重叠子问题,一些数组得到正确的答案,而另一些数组没有得到正确的答案。 只是为了比较&为了确保正确性,我实现了一个被称为Kadane算法的解决方案(我认为复杂度为Omega(n))。 这是Kand

  • 本文向大家介绍计算三元组(a,b,c)的数量,以使C ++中a ^ 2 + b ^ 2 = c ^ 2和1 <= a <= b <= c <= n,包括了计算三元组(a,b,c)的数量,以使C ++中a ^ 2 + b ^ 2 = c ^ 2和1 <= a <= b <= c <= n的使用技巧和注意事项,需要的朋友参考一下 我们得到一个整数n。目标是找到满足条件的三元组(3个数字一组)- a 2