向数组中添加最小数字,以便在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
热门推荐
10 香港老妈结婚祝福语简短
11 毕业立体贺卡祝福语简短
12 简短新年年会祝福语
13 评论小品祝福语大全简短
14 恭喜师兄结婚祝福语简短
15 员工集体辞职祝福语简短
16 高中新生祝福语 简短
17 装修祝福语男生搞笑简短
18 生日开业蛋糕祝福语简短