Bằng cách nhấp vào Đăng nhập, bạn đồng ý Chính sách bảo mật và Điều khoản sử dụng của chúng tôi. Nếu đây không phải máy tính của bạn, để đảm bảo an toàn, hãy sử dụng Cửa sổ riêng tư (Tab ẩn danh) để đăng nhập (New Private Window / New Incognito Window).
- Số đẹp thứ 10000 là 50695 nên đặt giới hạn là 1e5 cho tròn :)
- Số có tổng bình phương chữ số lớn nhất: 99999 (5.92=4055.92=405). Do đó ta sàng trước [1..405]
- Công thức (tính tổng b.p các số từ [1..n]): sum[i] = sum[i / 10] + (i)2(i)2
- Code:
#include <iostream>
#include <vector>
using namespace std;
const int Lim = 1e5;
vector<int> pr;
vector<int> lpf;
void linear_sieve(int n = 500) {
pr = {2};
lpf.assign(n + 1, 2);
for (int x = 3; x <= n; x += 2) {
if (lpf[x] == 2) pr.push_back(lpf[x] = x);
for (int i = 1; i < pr.size() && pr[i] <= lpf[x] && pr[i] * x <= n; ++i)
lpf[pr[i] * x] = pr[i];
}
}
bool prime(int x) {
if (x <= 1) return false;
return lpf[x] == x;
}
int n, sum[Lim + 1], res = 1;
int main() {
cin >> n;
linear_sieve();
for (int i = 1; i <= Lim; ++i) sum[i] = sum[i / 10] + ((i % 10) * (i % 10));
for (int i = 1; n > 0; ++i) {
if (prime(sum[i])) --n, res = i;
}
cout << res;
}
Hôm nay bạn thế nào? Hãy nhấp vào một lựa chọn, nếu may mắn bạn sẽ được tặng 50.000 xu từ Lazi
Vui | Buồn | Bình thường |