blob: 1fd4412a78343f08f78c71bade4f0b217f732bb9 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
#include <cmath>
#include <iostream>
int main() {
std::ios_base::sync_with_stdio(false);
std::cin.tie(nullptr);
int N, M;
std::cin >> N >> M;
long long result = 0;
long long min = 1e9 + 1;
long long max = -1e9 - 1;
for (int i = 0; i < N + M + 1; i++) {
long long a;
std::cin >> a;
max = std::max(a, max);
min = std::min(a, min);
if (M == 0) {
result += a;
} else {
result += std::abs(a);
}
}
if (M != 0 && max < 0) {
result += 2 * max;
}
if (M != 0 && min > 0) {
result -= 2 * min;
}
std::cout << result;
return 0;
}
|