在 C++ 中,向数组添加最少数量的数,使其总和变为偶数?


假设有一个包含一些数字的数组。我们必须确定最少需要向其添加多少个数字,才能使这些元素的总和变为偶数。这个数字必须大于0。因此,如果元素的总和为奇数,我们将添加1,但如果总和已经是偶数,那么我们将向其添加2,使其变为偶数。

算法

addMinNumber(arr)

begin
   s := 0
   for each element e from arr, do
      s := e + s
   done
   if s is even, then return 2, otherwise 1
end

示例

 在线演示

#include<iostream>
using namespace std;
int addMinNumber(int arr[], int n) {
   int sum = 0;
   for(int i = 0; i<n; i++) {
      sum += arr[i];
   }
   return (sum % 2)? 1 : 2;
}
main() {
   int arr[] = {5, 8, 4, 7, 5};
   int n = sizeof(arr)/sizeof(arr[0]);
   cout << "Minimum " << addMinNumber(arr, n) << " should be added";
}

输出

Minimum 1 should be added

更新于: 30-07-2019

82 个浏览量

开启你的 职业生涯

完成课程获得认证

开始使用
广告
© . All rights reserved.