递归(效率一般)
#include <bits/stdc++.h>
using namespace std;
bool g2(int a, int b) {
if(b > sqrt(a))
return true;
if(a % b == 0)
return false;
return g2(a, b + 1);
}
int f2(int n) {
int count = 0;
for(int i = 2; i <= n; i++) {
if(i == 1)
continue;
if(g2(i, 2))
count++;
}
return count;
}
int main() {
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
int n;
cin >> n;
cout << f2(n);
return 0;
}