मान लीजिए, हमारे पास एक पूर्णांक 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