在 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 個瀏覽量

開啟你的 職業生涯

完成課程獲得認證

開始使用
廣告