#include <bits/stdc++.h>
using namespace std;
#define rep(i, a) for (int i = 0; i < (a); i++)
#define FOR(i, m, n) for (int i = m; i < n; i++)
typedef pair<int, int> P;
typedef long long ll;
const int INF = 1001001001;
const int MOD = 1000000007;
const double PI = acos(-1);
int main() {
  ll H, W;
  cin >> H >> W;
  ll ans = INF;
  if (H % 3 == 0) {
    ans = 0;
  } else {
    ans = min(ans, W);
  }
  if (W % 3 == 0) {
    ans = 0;
  } else {
    ans = min(ans, H);
  }
  ll w, h;
  w = W / 3;
  if (H % 2 == 0) {
    ll a, b, c;
    a = w * H;
    b = H / 2 * (W - w);
    c = b;
    ll a_max = max(a, max(b, c));
    ll a_min = min(a, min(b, c));
    ans = min(ans, a_max - a_min);
  } else {
    ll a, b, c;
    a = w * H;
    b = H / 2 * (W - w);
    c = (H / 2 + 1) * (W - w);
    ll a_max = max(a, max(b, c));
    ll a_min = min(a, min(b, c));
    ans = min(ans, a_max - a_min);
  }
  w = W / 3 + 1;
  if (H % 2 == 0) {
    ll a, b, c;
    a = w * H;
    b = H / 2 * (W - w);
    c = b;
    ll a_max = max(a, max(b, c));
    ll a_min = min(a, min(b, c));
    ans = min(ans, a_max - a_min);
  } else {
    ll a, b, c;
    a = w * H;
    b = H / 2 * (W - w);
    c = (H / 2 + 1) * (W - w);
    ll a_max = max(a, max(b, c));
    ll a_min = min(a, min(b, c));
    ans = min(ans, a_max - a_min);
  }
  h = H / 3;
  if (W % 2 == 0) {
    ll a, b, c;
    a = h * W;
    b = W / 2 * (H - h);
    c = b;
    ll a_max = max(a, max(b, c));
    ll a_min = min(a, min(b, c));
    ans = min(ans, a_max - a_min);
  } else {
    ll a, b, c;
    a = h * W;
    b = W / 2 * (H - h);
    c = (W / 2 + 1) * (W - w);
    ll a_max = max(a, max(b, c));
    ll a_min = min(a, min(b, c));
    ans = min(ans, a_max - a_min);
  }
  cout << ans << endl;
}
