水仙花算法

所谓水仙花数,是指一个三位数其各位数字立方和等于该数本身。

例如:153是一个“水仙花数”,因为153=1的三次方+5的三次方+3的三次方。


1.程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。


<pre name="code" class="cpp">#include <iostream>
using namespace std;

int Narcissus(int x){
	int a, b, c;
	if (x < 100 || x>999)return 1;
	a = x/100; // 百位
	b = x%100/10; // 十位
	c = x%100%10; // 个位
	
	if (x == (a*a*a)+(b*b*b)+(c*c*c) ){
		cout<< "yes"<<endl;
	}else{
		cout<< "No"<<endl;
	}
}

int main(){
	int x;
	while(cin>>x){
		if (x == 0)break;
		Narcissus(x);
	}

	return 0;
}


 这题目是在acm上面看到的,参考了网上公布的原理,初学算法,多多指教^_^
                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值