用C语言实现水仙花数的判断

C语言方法:

方法一:

#include <stdio.h>
int  main( )
{ int n,a,b,c;
scanf(“%d”,&n); 
a=n%10;
b=n/10%10;
c=n/100;
if(n==a*a*a+b*b*b+c*c*c)
printf(“%d是水仙花数\n”, n); 
else printf(“%d不是水仙花数\n”, n); 
return 0;
}
#include<stdio.h>
#include<stdlib.h>
#include<stdbool.h>
int cube(const int n){
    return n*n*n;
}
bool
isNarcissistic(const int n){//判断是不是水仙花数
    int hundreds=n/100;
    int tens=n/10-hundreds*10;
    int ones=n%10;
    return cube(hundreds)+cube(tens)+cube(ones)==n;
}
int main(void){
    int i;
    for(i=100;i<1000;++i){
        if(isNarcissistic(i))
        printf("%d\n",i);
    }
    return 0;
}

方法三:

#include <stdio.h> 
#include <stdlib.h>
int main() 
{ 
    int i,j,k,n; 
    printf("'water flower'number is:"); 
    for(n=100;n<1000;n++) 
    { 
        i=n/100;/*分解出百位*/ 
        j=n/10%10;/*分解出十位*/ 
        k=n%10;/*分解出个位*/ 
        if(n==i*i*i+j*j*j+k*k*k) 
        { 
            printf("%-5d",n); 
        } 
    } 
    printf("\n");
    return 0;
} 

C++方法:

方法一:

#include<iostream>
using std::cout;
using std::endl;
#define f(a) (a)*(a)*(a)
int main() {
    for (int i = 100;i < 1000;i++)
        if (f(i % 10) + f(i / 10 % 10) + f(i / 100 % 10) == i)
            cout << i << endl;
    system("pause");
    return 0;
}

方法二:

#include<iostream>
#include<cmath>
using namespace std;
int main(])
{
    long n1, n2, a;
    int i;
    cout << "请输入Narcissistic number的位数:" << endl;
    cin >> i;
    cout << i << "位数的Narcissistic number包括:" << endl;
    for (n1 = pow(10, i - 1); n1 < pow(10, i); n1++)
    {
        n2 = 0;
        for (int j=0; j < i; j++)
        {
            a = pow(10, j);
            a = n1 / a;
            a = a % 10;
            a = pow(a, i);
            n2 = n2 + a;
        }
        if (n1 == n2)
            cout << n1 << endl;
    }
    return 0;
}

### 回答1: 水仙花数是指一个三位,其各个字的立方和等于该本身。例如,153是一个水仙花数,因为$1^3 + 5^3 + 3^3 = 153$。 以下是用C语言编写的判断水仙花数的代码: ```c #include <stdio.h> int main() { int num, digit, sum; for (num = 100; num < 1000; num++) { sum = 0; for (digit = num; digit > 0; digit /= 10) { int remainder = digit % 10; sum += remainder * remainder * remainder; } if (num == sum) { printf("%d是水仙花数\n", num); } } return 0; } ``` 上述代码使用了两个for循环来遍历所有的三位,并分别计算它们的各个位的立方和。如果计算结果等于原,则输出该水仙花数。 ### 回答2: 水仙花数是指一个n位(n≥3),它的每个位上的字的n次幂之和等于它本身。例如,153是一个水仙花数,因为1³+5³+3³=153。 要用C语言判断一个是否水仙花数,我们可以按照以下步骤编写代码: 1. 首先,声明一个整型变量用于存储要判断,例如num。 2. 使用scanf函从用户输入中读取一个,并将其赋值给变量num。 3. 声明一个变量total并初始化为0,用于存储每个位上的字的n次幂之和。 4. 声明一个变量temp并将num的值赋给它,作为临时变量用来进行运算。 5. 使用while循环将temp除以10,直到temp大于0,循环终止。 6. 在循环内部,每次将temp对10取余得到当前位上的字,并将该字的n次幂加到total上。 7. 判断total是否等于num,如果相等,则输出num是水仙花数,否则输出num不是水仙花数。 下面是完整的C语言代码示例: #include <stdio.h> int main() { int num, total = 0, temp; printf("请输入一个:"); scanf("%d", &num); temp = num; while (temp > 0) { total += (temp % 10) * (temp % 10) * (temp % 10); temp /= 10; } if (total == num) { printf("%d是水仙花数。\n", num); } else { printf("%d不是水仙花数。\n", num); } return 0; } 通过以上步骤,我们可以使用C语言判断一个是否水仙花数。 ### 回答3: 水仙花数是指一个3位,它的各位字的立方和等于其本身。为了用C语言判断水仙花数,我们可以按照以下步骤进行: 1. 声明变量并初始化:声明一个整型变量num,用于表示待判断。 2. 获取用户输入:使用scanf函从用户处接收一个3位,并将其赋值给num。 3. 判断是否水仙花数:根据水仙花数的定义,我们可以依次提取num的个位、十位和百位字。将这三个字分别存储在个位变量(digit1)、十位变量(digit2)和百位变量(digit3)中。 4. 计算立方和:使用pow函计算digit1、digit2和digit3的立方,并将结果分别存储在cube1、cube2和cube3中。 5. 判断是否水仙花数:如果cube1+cube2+cube3等于num,则输出“是水仙花数”,否则输出“不是水仙花数”。 以下是一段实现上述步骤的C代码示例: ```c #include <stdio.h> #include <math.h> int main() { int num, digit1, digit2, digit3, cube1, cube2, cube3; printf("请输入一个三位:"); scanf("%d", &num); digit1 = num % 10; // 获得个位 digit2 = (num / 10) % 10; // 获得十位 digit3 = num / 100; // 获得百位 cube1 = pow(digit1, 3); cube2 = pow(digit2, 3); cube3 = pow(digit3, 3); if (cube1 + cube2 + cube3 == num) { printf("是水仙花数\n"); } else { printf("不是水仙花数\n"); } return 0; } ``` 这段代码首先提示用户输入一个三位,并将其存储在变量num中。然后,我们使用取模运算和除法运算分别获得这个的个位、十位和百位字。接着,我们使用math.h库中的pow函计算这些字的立方,并将结果存储在相应的变量中。最后,我们判断这些立方和是否等于num,如果是,则输出“是水仙花数”,否则输出“不是水仙花数”。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

惑星撞地球

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值