สมมติว่า เรามีจำนวนเต็ม N เราต้องหาจำนวนเต็ม 1
ในการแก้ปัญหานี้ เราจะหาจำนวนตัวหารของตัวเลขทั้งหมดด้านล่าง N และจัดเก็บไว้ในอาร์เรย์ จากนั้นนับจำนวนเต็ม x โดยที่ x โดยที่ x + 1 มีจำนวนตัวหารบวกเท่ากันโดยการรันลูป
ตัวอย่าง
#include<iostream> #include<cmath> #define N 100005 using namespace std; int table[N], pre[N]; void findPositiveDivisor() { for (int i = 1; i < N; i++) { for (int j = 1; j * j <= i; j++) { if (i % j == 0) { if (j * j == i) table[i]++; else table[i] += 2; } } } int ans = 0; for (int i = 2; i < N; i++) { if (table[i] == table[i - 1]) ans++; pre[i] = ans; } } int main() { findPositiveDivisor(); int n = 15; cout << "Number of integers: " << pre[n] << endl; }
ผลลัพธ์
Number of integers: 2