数的分解——水仙花数 三大方法
硬性分解,所为硬性分解即是已知此数的位数进行的分解,如已知一个 5 位数的数 x,将其分解为
ge,shi,bai,qian,wan
wan=x/10000;
qian=x%10000/1000;
bai=x%1000/100;
shi=x%100/10;
ge=x%10;
循环分解,循环分解其优点是无需知道数的位数
#include
using namespace std;
int main()
{int n;cin>>n;int a[10000];int i=1;while(n>0){a[i++]=n%10; //取出最低位 n/=10; //把最低位拿走 }for(i--;i>=1;i--){cout<
递归法 利用函数的递归也可快速的进行数的分解,其优点是位数不限,比循环分解还要优越,且代码短
小精悍,执行时间短
从个位开始:
#include
using namespace std;
void printz(int n)
{if(n>0){cout<>n;printz(n); return 0;
}
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
