#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 的使用,起作用就是只要符合条件就停止,不再循环到判断条件,提高了效率。
第四周任务3
最新推荐文章于 2022-06-22 17:19:17 发布