Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> C++

เพิ่มจำนวนขั้นต่ำลงในอาร์เรย์เพื่อให้ผลรวมกลายเป็นคู่ใน 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