aboutsummaryrefslogtreecommitdiff
path: root/works/solutions/acwing/1247.cpp
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;
}