f | n = int(input()) | f | n = int(input()) |
| a = n ** (1 / 3) | | a = n ** (1 / 3) |
| j = 0 | | j = 0 |
| b = n % 9 | | b = n % 9 |
| if n % 9 > 4: | | if n % 9 > 4: |
| b = (n % 9) - 9 | | b = (n % 9) - 9 |
n | # print(b) | n | |
| if abs(b) > 2: | | if abs(b) > 2: |
| print("NO") | | print("NO") |
| else: | | else: |
| flag = 0 | | flag = 0 |
| l = [] | | l = [] |
| m = [] | | m = [] |
n | #print(int(a), a * 2 ** (2/3), int(2 ** (2 / 3) * a) + 1) | n | |
| for i in range(int(a), int(2 ** (2 / 3) * a) + 2): | | for i in range(int(a), int(2 ** (2 / 3) * a) + 2): |
| if n % i == 0: | | if n % i == 0: |
| flag = 1 | | flag = 1 |
| m.append(i) | | m.append(i) |
n | #print(flag, "1") | n | |
| #print("stage 1 clear", m, "m", flag) | | |
| m1 = [] | | m1 = [] |
| for item in m: | | for item in m: |
| if (item ** 2 - n / item) % 3 == 0: | | if (item ** 2 - n / item) % 3 == 0: |
| l.append(int((item ** 2 - n / item) / 3)) | | l.append(int((item ** 2 - n / item) / 3)) |
| flag = 2 | | flag = 2 |
n | #print(flag, "2") | n | |
| m1.append(item) | | m1.append(item) |
| m.clear() | | m.clear() |
n | #print("stage 2 clear", flag) | n | |
| #print(l, "l") | | |
| #print(m1, "m") | | |
| | | |
| for i in range(len(m1)): | | for i in range(len(m1)): |
n | #print(m1[i] ** 2 - 4 * l[i]) | n | |
| if (m1[i] ** 2 - 4 * l[i]) ** (1 / 2) % 1 == 0: | | if (m1[i] ** 2 - 4 * l[i]) ** (1 / 2) % 1 == 0: |
| flag += 1 | | flag += 1 |
n | #print(flag, "3") | n | |
| if flag >= 3: | | if flag >= 3: |
| print("YES") | | print("YES") |
| else: | | else: |
| print("NO") | | print("NO") |
| | | |
t | """for i in range(a): | t | |
| for j in range(i): | | |
| if i ** 3 + j ** 3 == n: | | |
| print("YES") | | |
| break | | |
| if i ** 3 + j ** 3 == n: | | |
| break | | |
| if i ** 3 + j ** 3 != n: | | |
| print("NO") | | |
| """ | | |
| | | |