写一个4位数水仙花代码
时间: 2024-05-21 15:13:01 浏览: 13
好的,以下是一个4位数水仙花代码:
#include <stdio.h>
#include <math.h>
int main()
{
int num, originalNum, remainder, n = 0, result = 0;
printf("请输入一个4位数: ");
scanf("%d", &num);
originalNum = num;
// 计算数字位数
while (originalNum != 0)
{
originalNum /= 10;
++n;
}
originalNum = num;
// 求出每一位数的立方和
while (originalNum != 0)
{
remainder = originalNum % 10;
result += pow(remainder, n);
originalNum /= 10;
}
if (result == num)
printf("%d 是一个水仙花数。", num);
else
printf("%d 不是一个水仙花数。", num);
return 0;
}
注:水仙花数指一个 n 位数 ( n≥3 ),它的每个位上的数字的 n 次幂之和等于它本身。例如一个三位数:153 = 1^3 + 5^3 + 3^3。
相关问题
java 4位数水仙花代码
下面是 java 4位数水仙花代码:
```
public class ArmstrongNumber {
public static void main(String[] args) {
int limit = 1000;
for(int i = 100; i < limit; i++){
int number = i;
int sum = 0;
while (number > 0){
int digit = number % 10;
sum = sum + digit * digit * digit;
number = number / 10;
}
if(sum == i){
System.out.print(i + " ");
}
}
}
}
```
这段代码能够输出在100~999范围内的所有水仙花数。
用c语言写一个水仙花代码
### 回答1:
我可以给你一个简单的水仙花代码:
#include <stdio.h>
int main()
{
int i, j, k, n;
printf("请输入一个三位数:");
scanf("%d", &n);
i = n / 100; //百位
j = n / 10 % 10; //十位
k = n % 10; //个位
if (n == i*i*i + j*j*j + k*k*k)
{
printf("%d 是水仙花数", n);
}
else
{
printf("%d 不是水仙花数", n);
}
return 0;
}
### 回答2:
水仙花数是一个三位数,它的各个数位上的数字的立方和等于它本身。换句话说,如果一个三位数abc满足abc = a^3 + b^3 + c^3,那么它就是一个水仙花数。
要编写一个C语言程序来找到所有的水仙花数,可以按照以下步骤进行:
1. 包含头文件stdio.h,以便使用printf函数。
2. 声明一个整数变量num,用于迭代所有三位数。
3. 使用一个for循环从100到999迭代num的所有可能值。
4. 在循环中,将num的百位数、十位数和个位数分别保存到变量a、b和c中。
5. 计算num是否为水仙花数,判断条件是num等于a的立方加上b的立方加上c的立方。
6. 如果是水仙花数,使用printf函数输出num的值。
7. 完成循环后,程序将输出所有的水仙花数。
下面是一个示例代码:
#include <stdio.h>
int main() {
int num, a, b, c;
printf("所有的水仙花数是:\n");
for (num = 100; num <= 999; num++) {
a = num / 100; // 获取百位数
b = (num % 100) / 10; // 获取十位数
c = num % 10; // 获取个位数
if (num == (a * a * a) + (b * b * b) + (c * c * c)) {
printf("%d\n", num);
}
}
return 0;
}
这段代码将输出所有的三位数的水仙花数,结果为:
153
370
371
407
### 回答3:
水仙花数又称为自恋数或超完全数字不变数,是指一个3位数,该数字每个位上的数字立方和等于该数字本身。例如:153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。
下面是使用C语言编写的水仙花数代码:
```c
#include <stdio.h>
int main() {
int num, originalNum, remainder, result = 0;
printf("请输入一个3位数:");
scanf("%d", &num);
originalNum = num;
while (originalNum != 0) {
remainder = originalNum % 10;
result += remainder * remainder * remainder;
originalNum /= 10;
}
if (result == num)
printf("%d是一个水仙花数。\n", num);
else
printf("%d不是一个水仙花数。\n", num);
return 0;
}
```
这段程序首先要求用户输入一个3位数,然后通过循环依次计算每个位上数字的立方和,最后与原始输入的数字进行比较。如果两者相等,则打印出该数字是一个水仙花数,否则打印出该数字不是一个水仙花数。
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)