#include <iostream>
using namespace std;
class NaturalNumber
{
private:
int n;
public:
void setValue(int x);
int getValue();
bool isPrime();
void printFactor();
bool isPerfect();
bool isReverse(int x);
bool isDaffodil(int x);
void printDaffodils();
};
void main(void)
{
NaturalNumber w;
w.setValue(6);
cout<<w.getValue()<<(w.isPrime()?"是":"不是")<<"素数"<<endl;
w.setValue(37);
cout<<w.getValue()<<(w.isPrime()?"是":"不是")<<"素数"<<endl;
w.setValue(84);
cout<<w.getValue()<<"的因子有:";
w.printFactor();
}
void NaturalNumber::setValue(int x)
{
n=x;//不用cin
}
int NaturalNumber::getValue()
{
return n;
}
bool NaturalNumber:: isPrime()
{
bool prime=true;
for(int i=2;i<n;i++)
{
if(n%i==0)
{
prime= false;
break;
}
}
return prime;
}
void NaturalNumber::printFactor()
{
for(int i=1;i<=n;i++)
{
if(n%i==0)
{
cout<<i<<'\t';
}
}
}
bool NaturalNumber::isPerfect()
{
int s=0;
for(int i=1;i<n;i++)
{
if(n%i==0)
{
s=s+i;
}
}
if(n==s)
{
cout<<n<<"是完全数";
}
else if(n!=s)
{
cout<<n<<"不是完全数";
}
return 0;
}
bool NaturalNumber::isReverse(int x)
{
int s=0;
for(int i=1;x!=0;i++)
{
s=s+x%10;
s=s*10;
x=x/10;
}
if(s==n)
{
cout<<x<<"是逆向数";
}
else if(s!=n)
{
cout<<x<<"不是逆向数";
}
return 0;
}
bool NaturalNumber::isDaffodil(int x)
{
int s=0,k,m,i;
for(i=1;x!=0;i++)
{
m=x%10;
k=m*m*m;
x=x/10;
s=s+k;
}
if(s==x)
{
cout<<x<<"是水仙数";
}
else if(s!=x)
{
cout<<x<<"不是水仙数";
}
return 0;
}
void NaturalNumber::printDaffodils()
{
for(int x=2;x<n;x++)
{
int s=0,k,m,i;
for(i=1;x!=0;i++)
{
m=x%10;
k=m*m*m;
x=x/10;
s=s+k;
}
if(s==x)
{
cout<<x<<"是水仙数";
}
}
}
感悟:1.注意第一个函数 的使用,不再是以往的 cin,而是采用赋值 的方式得到函数值的。
2.注意break 的使用,起作用就是只要符合条件就停止,不再循环到判断条件,提高了效率。
本文介绍了一个用C++实现的自然数类,该类包括判断素数、打印因子、判断是否为完全数、判断是否为逆向数、判断是否为水仙花数等功能,并提供了具体的实现代码。





