C语言习题:循环结构部分——输出水仙花数

[题目]:输出水仙花数。输入一个正整数 n ( 3≤n≤7 ), 输出所有的 n 位水仙花数。水仙花数是指一个 n 位正整数,它的各 位数字的 n 次幕之和等于它本身。 例如 153 的各位数字的立方和是  1^3+5^3+3^3 =153。试编写相应程序

[解析]:输入位数:n位,例如输入3则100-999中所有水仙花的数 
          水仙花数计算:153
                                  153=1的3次方+5的3次+3的3次则为水仙花数 
                                  153/100=1,153%100=53
                                   53/10=5,53%10=3
                                   3/1=1;

[代码]:

#include<stdio.h>
#include<math.h>
int main(void){
	int n; 
	do{
		printf("intput n(3<=n<=7):");
		scanf("%d",&n);
		
	}while(n>7||n<3);
	printf("水仙花数有:\n");
	//如果我们输入的数位3位数,那么i取;999,998,997.....100
	//根据给定的n划分上下范围 
	int i=pow(10,n)-1;
	//定义界限值,最小值,三位数-100
	int limit=pow(10,n-1);
	int digit,sum,s,m;
	//我们循环从大数到小数如果,超出那个下限跳出 
	while(i>=limit){
		sum=0;
		//为了不改变m,和n 的值 
		s=i;
		m=n;
		//获取每个位的数字
		while(s!=0){
			//获取最高位的数字 
			digit = s/pow(10,m-1);
			s=s%(int)pow(10,m-1); 
			m--;
			sum+=pow(digit,n);
		}
		//计算符合,则是水仙花数 
		if(sum==i){
			printf("%d\t",i);
		} 
		//下一个数在进入循环 
		i--;
	} 
	printf("\n");
	return 0;
}

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值