#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef pair<int, int> pii;
typedef pair<int, pii> pipii;
typedef pair<pii, pii> piipii;
#define all(a) (a).begin(), (a).end()
#define sz(a) (int)(a).size()
#define eb emplace_back
int d;
int D[25];
ll dp[25][25][2][2];
int L;
ll dfs(int l, int r, int b0, int b1) {
  if (dp[l][r][b0][b1] != -1)
    return dp[l][r][b0][b1];
  ll ans = 0;
  if (l + 1 == r) {
    for (int a = 0; a <= 9; a++) {
      for (int b = 0; b <= 9; b++) {
        if (r == L && a == 0)
          continue;
        for (int x = 0; x < 2; x++) {
          for (int y = 0; y < 2; y++) {
            int A = a, B = b;
            if (x == 1)
              A = A + 10;
            if (y == 1)
              B = B - 1;
            if (b0 == 1)
              A = A - 1;
            if (b1 == 1)
              B = B + 10;
            if (A - b == D[l] && B - a == D[r]) {
              if (x == y) {
                ans++;
              }
            }
          }
        }
      }
    }
  } else if (l == r) {
    for (int a = 0; a <= 9; a++) {
      if (r == L && a == 0)
        continue;
      int A = a;
      if (b0 == 1)
        A = A - 1;
      if (b1 == 1)
        A = A + 10;
      if (A - a == D[l])
        ans++;
    }
  } else {
    for (int a = 0; a <= 9; a++) {
      for (int b = 0; b <= 9; b++) {
        if (r == L && a == 0)
          continue;
        for (int x = 0; x < 2; x++) {
          for (int y = 0; y < 2; y++) {
            int A = a, B = b;
            if (x == 1)
              A = A + 10;
            if (y == 1)
              B = B - 1;
            if (b0 == 1)
              A = A - 1;
            if (b1 == 1)
              B = B + 10;
            if (A - b == D[l] && B - a == D[r])
              ans += dfs(l + 1, r - 1, x, y);
          }
        }
      }
    }
  }
  return dp[l][r][b0][b1] = ans;
}
ll solve(int l) {
  memset(dp, -1, sizeof(dp));
  L = l;
  return dfs(1, l, 0, 0);
}
int main() {
  scanf("%d", &d);
  int x = d, l = 0;
  while (x) {
    l++;
    D[l] = x % 10;
    x /= 10;
  }
  for (int i = l + 1; i <= 20; i++)
    D[i] = 0;
  ll ans = 0;
  for (int i = l; i <= 20; i++)
    ans += solve(i);
  printf("%lld\n", ans);
}