#include <algorithm>
#include <array>
#include <bitset>
#include <cassert>
#include <cctype>
#include <cfloat>
#include <climits>
#include <cmath>
#include <complex>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <ctime>
#include <iostream>
#include <list>
#include <map>
#include <numeric>
#include <queue>
#include <random>
#include <set>
#include <sstream>
#include <stack>
#include <string>
#include <unordered_map>
#include <vector>
using namespace std;
typedef long long LL;
typedef pair<int, int> P;
const int inf = 1e8;
const int L = 5000;
int dp[L], dn[L];
int main() {
  int N, Ma, Mb;
  scanf("%d%d%d", &N, &Ma, &Mb);
  for (int i = 1; i < L; i++) {
    dp[i] = inf;
    dn[i] = inf;
  }
  int ret = inf;
  for (int i = 0; i < N; i++) {
    int a, b, c;
    scanf("%d%d%d", &a, &b, &c);
    int v = Ma * b - Mb * a;
    if (v == 0) {
      ret = min(ret, c);
    } else if (v > 0) {
      for (int j = L - 1; j >= v; j--) {
        dp[j] = min(dp[j], dp[j - v] + c);
      }
    } else {
      v = -v;
      for (int j = L - 1; j >= v; j--) {
        dn[j] = min(dn[j], dn[j - v] + c);
      }
    }
  }
  for (int i = 1; i < L; i++) {
    ret = min(ret, dp[i] + dn[i]);
  }
  if (ret == inf) {
    puts("-1");
  } else {
    printf("%d\n", ret);
  }
  return 0;
}
