#include <bits/stdc++.h>
using namespace std;
int main() {
int n;
cin >> n;
vector<int> cnt(n + 1, 0);
for (int i = 2; i <= n; i++) {
if (cnt[i] == 0) {
for (int j = i; j <= n; j += i) {
int x = j;
while (x % i == 0) {
cnt[j]++;
x /= i;
}
}
}
}
vector<bool> prime(n + 1, true);
prime[0] = prime[1] = false;
for (int i = 2; i * i <= n; i++) {
if (prime[i]) {
for (int j = i * i; j <= n; j += i) {
prime[j] = false;
}
}
}
int ans = 0;
for (int i = 2; i <= n; i++) {
if (prime[cnt[i]]) {
ans++;
}
}
cout << ans;
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CnVzaW5nIG5hbWVzcGFjZSBzdGQ7CgppbnQgbWFpbigpIHsKICAgIGludCBuOwogICAgY2luID4+IG47CgogICAgdmVjdG9yPGludD4gY250KG4gKyAxLCAwKTsKCgogICAgZm9yIChpbnQgaSA9IDI7IGkgPD0gbjsgaSsrKSB7CiAgICAgICAgaWYgKGNudFtpXSA9PSAwKSB7CiAgICAgICAgICAgIGZvciAoaW50IGogPSBpOyBqIDw9IG47IGogKz0gaSkgewogICAgICAgICAgICAgICAgaW50IHggPSBqOwogICAgICAgICAgICAgICAgd2hpbGUgKHggJSBpID09IDApIHsKICAgICAgICAgICAgICAgICAgICBjbnRbal0rKzsKICAgICAgICAgICAgICAgICAgICB4IC89IGk7CiAgICAgICAgICAgICAgICB9CiAgICAgICAgICAgIH0KICAgICAgICB9CiAgICB9CgogICAgdmVjdG9yPGJvb2w+IHByaW1lKG4gKyAxLCB0cnVlKTsKICAgIHByaW1lWzBdID0gcHJpbWVbMV0gPSBmYWxzZTsKCiAgICBmb3IgKGludCBpID0gMjsgaSAqIGkgPD0gbjsgaSsrKSB7CiAgICAgICAgaWYgKHByaW1lW2ldKSB7CiAgICAgICAgICAgIGZvciAoaW50IGogPSBpICogaTsgaiA8PSBuOyBqICs9IGkpIHsKICAgICAgICAgICAgICAgIHByaW1lW2pdID0gZmFsc2U7CiAgICAgICAgICAgIH0KICAgICAgICB9CiAgICB9CgogICAgaW50IGFucyA9IDA7CgogICAgZm9yIChpbnQgaSA9IDI7IGkgPD0gbjsgaSsrKSB7CiAgICAgICAgaWYgKHByaW1lW2NudFtpXV0pIHsKICAgICAgICAgICAgYW5zKys7CiAgICAgICAgfQogICAgfQoKICAgIGNvdXQgPDwgYW5zOwp9