#include "bits/stdc++.h" #define ALL(obj) (obj).begin(),(obj).end() #define RALL(obj) (obj).rbegin(),(obj).rend() #define REP(i, n) for(int i = 0; i < (int)(n); i++) #define REPR(i, n) for(int i = (int)(n); i >= 0; i--) #define FOR(i,n,m) for(int i = (int)(n); i < int(m); i++) using namespace std; typedef long long ll; const int MOD = 1e9 + 7; const int INF = 1e9 + 6; const ll LLINF = 4e18; //gcd template T gcd(T a, T b) { return b ? gcd(b, a%b) : a; } int main() { int L; cin >> L; ll ans = 0; for (int i = 2; 8*i*i < L; i++) { for (int j = 1; 8 * i*(i + j) <= L; j++) { if (i <= j) break; if (gcd(i*i-j*j,gcd(2*i*j,i*i+j*j))!=1) continue; ans++; } } cout << ans << endl; getchar(); getchar(); }