#include <float.h>
#include <inttypes.h>
#include <limits.h>
#include <math.h>
#include <stdbool.h>
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <time.h>
#include <unistd.h>
#ifdef __cplusplus
#include <bits/stdc++.h>
#endif
void rsortr_u32(void *base, const int count) {
  uint32_t *a = base;
  uint32_t *b = malloc(count * sizeof(uint32_t));
  int c[0x100];
  memset(c, 0, sizeof(c));
  for (int i = 0; i < count; i++) {
    c[(a[i] >> (0 << 3)) & 0xFF]++;
  }
  for (int i = 0xFE; i >= 0; i--)
    c[i] += c[i + 1];
  for (int i = count - 1; i >= 0; i--) {
    b[--c[(a[i] >> (0 << 3)) & 0xFF]] = a[i];
  }
  {
    void *t = a;
    a = b;
    b = t;
  }
  memset(c, 0, sizeof(c));
  for (int i = 0; i < count; i++) {
    c[(a[i] >> (1 << 3)) & 0xFF]++;
  }
  for (int i = 0xFE; i >= 0; i--)
    c[i] += c[i + 1];
  for (int i = count - 1; i >= 0; i--) {
    b[--c[(a[i] >> (1 << 3)) & 0xFF]] = a[i];
  }
  {
    void *t = a;
    a = b;
    b = t;
  }
  memset(c, 0, sizeof(c));
  for (int i = 0; i < count; i++) {
    c[(a[i] >> (2 << 3)) & 0xFF]++;
  }
  for (int i = 0xFE; i >= 0; i--)
    c[i] += c[i + 1];
  for (int i = count - 1; i >= 0; i--) {
    b[--c[(a[i] >> (2 << 3)) & 0xFF]] = a[i];
  }
  {
    void *t = a;
    a = b;
    b = t;
  }
  memset(c, 0, sizeof(c));
  for (int i = 0; i < count; i++) {
    c[(a[i] >> (3 << 3)) & 0xFF]++;
  }
  for (int i = 0xFE; i >= 0; i--)
    c[i] += c[i + 1];
  for (int i = count - 1; i >= 0; i--) {
    b[--c[(a[i] >> (3 << 3)) & 0xFF]] = a[i];
  }
  {
    void *t = a;
    a = b;
    b = t;
  }
  free(b);
}
int32_t nextint(void) {
  char c = getchar_unlocked();
  while (c != '-' && (c < '0' || '9' < c))
    c = getchar_unlocked();
  int s = 0;
  if (c == '-') {
    s = 1;
    c = getchar_unlocked();
  }
  uint32_t x = 0;
  while ('0' <= c && c <= '9') {
    x = x * 10 + c - '0';
    c = getchar_unlocked();
  }
  return s ? -x : x;
}
int n;
int w, x;
int a[4][101];
int b[4] = {1, 1, 1, 1};
int main(void) {
  n = nextint();
  x = nextint();
  w = nextint();
  a[0][b[0]++] = nextint();
  for (int i = 1; i < n; i++) {
    int W = nextint() - w;
    int v = nextint();
    a[W][b[W]++] = v;
  }
  for (int k = 0; k < 4; k++) {
    rsortr_u32(&a[k][1], b[k]);
    for (int i = 1; i <= b[k]; i++) {
      a[k][i] += a[k][i - 1];
    }
  }
  int ans = 0;
  for (int i0 = 0; i0 <= b[0]; i0++) {
    for (int i1 = 0; i1 <= b[1]; i1++) {
      for (int i2 = 0; i2 <= b[2]; i2++) {
        for (int i3 = 0; i3 <= b[3]; i3++) {
          long W = (long)w * i0 + (long)(w + 1) * i1 + (long)(w + 2) * i2 +
                   (long)(w + 3) * i3;
          if (W <= x) {
            int now = a[0][i0] + a[1][i1] + a[2][i2] + a[3][i3];
            if (now > ans)
              ans = now;
          }
        }
      }
    }
  }
  printf("%d\n", ans);
}
