即使在C ++中,最小移除也可以使数组求和
问题陈述
给定一个N个整数的数组arr[]。我们需要编写一个程序来查找需要从数组中删除的最小元素数,以便剩余元素的总和为偶数。
示例
如果输入数组为{10,20,30,5},那么我们需要删除一个元素(即5)以使数组求和
算法
1. Sum of any number of even numbers is always even 2. Sum of odd numbers of odd numbers is always odd 3. Sum of odd numbers of even times is always even 4. Count the number of odd elements in the array. If the count of odd elements in the array is even, then we do not need to remove any element from the array but if the count of odd elements in the array is odd then by removing any one of the odd elements from the array
示例
#include <bits/stdc++.h>
using namespace std;
int getMinRemovals(int *arr, int n) {
int cnt = 0;
for (int i = 0; i < n; ++i) {
if (arr[i] % 2 == 1) {
++cnt;
}
}
return (cnt % 2 == 0) ? 0 : 1;
}
int main() {
int arr[] = {10, 20, 30, 5};
int n = sizeof(arr) / sizeof(arr[0]);
cout << "Minimum required removals = " << getMinRemovals(arr, n) << endl;
return 0;
}当您编译并执行上述程序时。它产生以下输出
输出结果
Minimum required removals = 1
热门推荐
10 对上司的简短祝福语
11 历史老师蛋糕祝福语简短
12 给老人的祝福语简短
13 生日祝福语舅舅 简短独特
14 新年的祝福语简短的
15 小年好的祝福语简短
16 送离别同事简短祝福语
17 高考给舍友祝福语简短
18 早餐祝福语怎么写简短