c语言,输出所有的水仙花数的问题

哪错了,初学者不太清楚,谢谢指教

楼主你好~~
按照你的程序,你可能对于水仙话数有误解...

首先,水仙花数是指一个 n 位数 ( n≥3 ),它的每个位上的数字的 n 次幂之和等于它本身。(例如:1^3 + 5^3 + 3^3 = 153或3^3+7^3+0^3=370)
注意:是每个 位上 的数字。

而你的原代码写的效果是,例如第一次循环1^3+10^3+100^3=111,这样的表示是错的,按定义应该是判断1^3+1^3+1^3 是否等于111,当然明显是不等的,所以111不是水仙花数。

而且这个代码还要考虑一件事,就是除了最高位百位外,十位和个位都有可能是0,所以,分别代表十位和个位的b与a应当从0开始循环到9,而百位的c则是从1循环到9~~

综上所述,修改的代码如下:
#include<stdio.h>
void main()
{
int a,b,c;
for(a=0;a<10;a++) //个位的a由0开始
for(b=0;b<10;b++) //十位的b由0开始
for(c=1;c<10;c++) //百位的c由1开始
if(a+b*10+c*100==a*a*a+b*b*b+c*c*c) //注意a,b,c都是单独一个数字,要组成3位数必须使其按位乘以10或者100
printf("%d,%d,%d\n",c,b,a); //按照百、十、个的顺序输出结果
}

希望楼主能看明白哈~~祝楼主学习进步~望采纳~谢谢~
温馨提示:内容为网友见解,仅供参考
第1个回答  2012-11-08
LZ你好~
首先你要理解啥是水仙花数:

水仙花数是指一个 n 位数 ( n≥3 ),它的每个位上的数字的 n 次幂之和等于它本身。(例如:1^3 + 5^3 + 3^3 = 153)

以上来自百度百科。

按照楼主的程序,有3层循环,姑且叫做a循环,b循环,c循环。
我们先从循环上下界和条件来看:
楼主用a循环代表个位数,用b循环代表10位数,c循环代表百位数,对嘛?假设是这种情况,让我们先不看代码。
事实上a循环是最外面的循环,c循环是最里面的循环,而计数按照逻辑应该是 111,112,113这样增长的,所以逻辑上应该反过来,a代表百位数,b代表10位数,c代表个位数。(其实您的方式也可以遍历所有您想遍历的数,只不过从逻辑上变成111,211,311...911,121,221...这样了,但是不觉得很不舒服嘛~)
然后我们来分析代码,结构很明白了:
a循环,百位数
{
b循环,十位数
{
c循环,个位数
{
验证

}

}

}

然后我们来确定验证:
一个水仙花数n,假设是1000以内的3位数,写作abc也就是 n = a*100 + b*10 + c = a^3 + b^3 + c^3,这不就是验证条件嘛?所以条件就是a*100 + b*10 + c = a*a*a + b*b*b + c*c*c;

然后来看循环上下界,百位数可以从1-9,十位数可以从0-9,个位可以从0-9,这时候程序就完成了啦。

楼主在确定上下界的时候犯了错哦,十位数不可以当做10到99,你要单纯的将她看成数字,因为十位数只可能出现0-9,这10种情况,而不会出现11,23,56这样的情况吧?

所以关键的循环体应该是:

for(a=1;a<=9;a++)
{
for(b=0;b<=9;b++)
{
for(c=0;c<=9;c++)
{
if(a*100 + b*10 + c == a*a*a + b*b*b + c*c*c)
{
printf("%d,%d,%d\n",a,b,c);

}

}

}

}

我把大括号全带上了,请养成良好的编程习惯哦~
当然你也可以把最后验证部分(if部分)替换成三元表达式,使用某一些编译器效率会提高一点:

for(a=1;a<=9;a++)
for(b=0;b<=9;b++)
for(c=0;c<=9;c++)
a*100 + b*10 + c == a*a*a + b*b*b + c*c*c ? printf("%d,%d,%d\n",a,b,c):; // 注意有个':'
第2个回答  2012-11-07
你是要源程序,还是想知道什么是水仙花数?

如何实现用C语言输出所有的“水仙花数”?
输出所有的“水仙花数”,所谓的“水仙花数”是指一个三位数其各位数字的立方和等于该数本身,例如153是“水仙花数”,因为:153 = 13 + 53 + 33。二、问题分析:根据“水仙花数”的定义,判断一个数是否为“水仙花数”,最重要的是要把给出的三位数的个位、十位、百位分别拆分,并求其立方和(...

如何实现用C语言输出所有的“水仙花数”?
1. 问题定义:目标是寻找所有三位数,其每个位上数字的立方和等于该数本身。例如,153是一个“水仙花数”,因为153 = 1^3 + 5^3 + 3^3。2. 分析问题:要验证一个三位数是否为“水仙花数”,需要将该数拆分为百位、十位和个位上的数字,计算这三个数字的立方和,如果立方和等于原数,则该数...

c语言中,如何输出所有的水仙花数
1. 确定水仙花数的定义:水仙花数,也就是三位自幂数,指的是一个三位数,它的每个位上的数字的立方和等于它本身。2. 编写判断水仙花数的函数:这个函数需要提取输入数值的个位、十位和百位数字,计算它们的立方和,并与原数值比较以确定是否为水仙花数。3. 遍历所有三位数:从100到999,对每个数使用...

在C语言中输出所有水仙花,并统计水仙花个数,使用while语句?_百度知 ...
include <stdio.h> int main(){ int i,cnt;for(i=100,cnt=0;i<1000;++i){ if(i==(i%10)*(i%10)*(i%10)+(i\/10%10)*(i\/10%10)*(i\/10%10)+(i\/100)*(i\/100)*(i\/100)){ printf("%d\\n",i);cnt++;} } printf("%d\\n",cnt);return 0;} ...

c语言中,如何输出所有的水仙花数
在C语言中,输出所有的水仙花数的步骤如下:1. 首先,我们需要理解水仙花数的定义。水仙花数,也称为自幂数,是指一个三位数,它的每个位上的数字的立方和等于它本身。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。2. 接下来,我们需要编写一个函数来判断一个数是否为水仙花数。

水仙花数用C语言怎么表示?
C语言写水仙花数要将给出的三位数的个位、十位、百位分别拆分,并求其立方和(设为s),若s与给出的三位数相等, 三位数为“水仙花数”,反之,则不是水仙花数。include <stdio.h> int main(){ int hun, ten, ind, n;printf("result is:");for( n=100; n<1000; n++ ) \/*整数的...

C语言题目:输出所有的“水仙花数”,并输出其总个数。所谓“水仙花数”是...
void main(){ int i,a,b,c,count=0;\/\/count是计数器 printf("水仙花数有\\n");for (i=100;i<=999;i++){ a=i\/100; \/\/取百位数字 b=(i-a*100)\/10; \/\/取十位数字 c=i%10; \/\/取个位数字 if(a*a*a+b*b*b+c*c*c==i)\/\/如果是水仙花数 { printf("%d\\t",i);...

C语言:输出100-999中所有水仙花数。
1. 输出100-999中所有水仙花数。```c void OutputNarcissusNumbers() { for (int i = 100; i < 1000; i++) { int sum = 0;int temp = i;int rem;for (int j = 0; j < 3; j++) { rem = temp % 10;temp \/= 10;sum += rem * rem * rem;} if (sum == i) { pr...

程序设计题找出所有的“水仙花数”,所谓“水仙花数”是指一个三位数...
水仙花数是指一个三位数,它的每个位上的数字的立方和等于它本身。例如:153 是一个水仙花数,因为 1^3 + 5^3 + 3^3 = 153。下面是一个简单的C语言程序,用来找出所有的水仙花数:```c include int main() { int a, b, c, i;for(i = 100; i <= 999; i++) { a = i \/ ...

输出所有的“水仙花数”用c语言程序怎么做?水仙花数例;153=1^3+5^...
以下是使用C语言编写的程序,用于找出所有的水仙花数。请注意,每个条目都应该是一段独立的代码块,以保证清晰的条理性和可读性。```c include int main() { int i, j, k;for (i = 1; i <= 9; i++) { for (j = 0; j <= 9; j++) { for (k = 0; k <= 9; k++) { i...

相似回答