Please note, this is a STATIC archive of website www.w3resource.com from 19 Jul 2022, cach3.com does not collect or store any user information, there is no "phishing" involved.
w3resource

C++ Exercises: Generate and show all Kaprekar numbers less than 1000

C++ Numbers: Exercise-10 with Solution

Write a program in C++ to generate and show all Kaprekar numbers less than 1000.

Pictorial Presentation:

C++ Exercises: Generate and show all Kaprekar numbers less than 1000

Sample Solution:

C++ Code :

#include<bits/stdc++.h>
using namespace std;
 
bool chkkaprekar(int n)
{
    if (n == 1)
       return true;
 

    int sqr_n = n * n;
    int ctr_digits = 0;
    while (sqr_n)
    {
        ctr_digits++;
        sqr_n /= 10;
    }
 
    sqr_n = n*n; 
 
    for (int r_digits=1; r_digits<ctr_digits; r_digits++)
    {
         int eq_parts = pow(10, r_digits);

         if (eq_parts == n)
            continue;
 
         int sum = sqr_n/eq_parts + sqr_n % eq_parts;
         if (sum == n)
           return true;
    }
    return false;
}
int main()
{
 cout << "\n\n Generate and show all Kaprekar numbers less than 1000: \n";
 cout << " -----------------------------------------------------------\n";
   cout << " The Kaprekar numbers less than 1000 are: "<<endl;
   for (int i=1; i<1000; i++)
      {
          if (chkkaprekar(i))
          {
              cout << i << " ";
              
          }
          
      }
          cout <<endl; 
    return 0;
}

Sample Output:

 Generate and show all Kaprekar numbers less than 1000:                
 -----------------------------------------------------------           
 The Kaprekar numbers less than 1000 are:                              
1 9 45 55 99 297 703 999  

Flowchart:

Flowchart: Generate and show all Kaprekar numbers less than 1000

C++ Code Editor:

Contribute your code and comments through Disqus.

Previous: Write a program in C++ to check whether a given number is a Kaprekar number or not.
Next: Write a program in C++ to check whether a number is Lychrel number or not.

What is the difficulty level of this exercise?