写一个c语言的求出水仙花数的程序
时间: 2023-05-23 12:05:54 浏览: 111
以下是一个c语言求出水仙花数的程序:
```
#include <stdio.h>
int main() {
int i, n, sum, temp; // 初始化变量
printf("请输入一个三位数:");
scanf("%d", &n);
printf("水仙花数有:");
for(i = 100; i <= n; i++) { // 从100开始循环到用户输入的数n
temp = i; // 将当前的i复制给temp以便后面使用
sum = 0; // 初始化sum
while(temp) { // 循环计算各位的立方和
int m = temp % 10;
sum += m * m * m;
temp /= 10;
}
if(sum == i) { // 如果sum等于i,说明是水仙花数,输出
printf("%d ", i);
}
}
printf("\n");
return 0;
}
```
运行程序后,用户可以输入一个三位数,程序会从100开始依次循环到这个数,并判断每个数是否是水仙花数。如果是,它就会被输出。
相关问题
写一个C语言程序判断水仙花数
### 回答1:
我可以给你一些提示来帮助你开始编写这个程序。首先,你需要定义一个变量来存储用户输入的数字。然后,你需要使用for循环来遍历每一位数字,并将其求出立方。最后,你需要检查这些立方和是否等于用户输入的数字。如果是,那么它就是一个水仙花数;如果不是,则不是。
### 回答2:
水仙花数是指一个 n 位数(n≥3)的各个位上的数字的 n 次幂之和等于它本身的数。例如,153是一个3位水仙花数,因为 1^3 + 5^3 + 3^3 = 153。
下面是一个使用C语言编写的程序,用于判断水仙花数:
```c
#include <stdio.h>
#include <math.h>
int isArmstrongNumber(int number) {
int originalNumber, remainder, result = 0, n = 0;
originalNumber = number;
// 计算数字的位数
while (originalNumber != 0) {
originalNumber /= 10;
++n;
}
originalNumber = number;
// 计算各个位数的 n 次幂之和
while (originalNumber != 0) {
remainder = originalNumber % 10;
result += pow(remainder, n);
originalNumber /= 10;
}
// 检查是否为水仙花数
if (result == number) {
return 1;
} else {
return 0;
}
}
int main() {
int number;
printf("请输入一个数字: ");
scanf("%d", &number);
if (isArmstrongNumber(number)) {
printf("%d 是一个水仙花数。\n", number);
} else {
printf("%d 不是一个水仙花数。\n", number);
}
return 0;
}
```
编译并运行该程序,用户可以输入一个数字,程序将判断该数字是否为水仙花数,并输出相应的结果。
### 回答3:
对于判断水仙花数的C语言程序,可以使用以下代码:
#include <stdio.h>
int main() {
int number, originalNumber, remainder, result = 0;
printf("请输入一个三位数: ");
scanf("%d", &number);
originalNumber = number;
while (originalNumber != 0) {
remainder = originalNumber % 10;
result += remainder * remainder * remainder;
originalNumber /= 10;
}
if (result == number)
printf("%d是一个水仙花数。\n", number);
else
printf("%d不是一个水仙花数。\n", number);
return 0;
}
以上程序首先要求用户输入一个三位数,并将其保存在变量number中。
然后,将原始数字保存在变量originalNumber中。
接下来,使用while循环通过取余数的方式将原始数字的每一位进行立方运算,并将结果相加存储在result变量中。
最后,通过将result与原始输入的number进行比较,判断是否为水仙花数。
如果result与number相等,则打印"%d是一个水仙花数。",否则打印"%d不是一个水仙花数。"。
以上是一个简单的判断水仙花数的C语言程序。
c语言写出水仙花数两边的第一个素数
以下是一个求水仙花数并找到两边的第一个素数的C语言程序:
```c
#include <stdio.h>
#include <math.h>
int is_prime(int n) { // 判断是否为素数
if (n < 2) {
return 0;
}
int i;
for (i = 2; i <= sqrt(n); i++) {
if (n % i == 0) {
return 0;
}
}
return 1;
}
int main() {
int n, i, j, digit, sum;
printf("请输入一个三位数:");
scanf("%d", &n);
for (i = n - 1; i >= 100; i--) { // 从输入的数的左边开始找水仙花数
digit = (int)log10(i) + 1; // 计算位数
sum = 0;
int temp = i;
while (temp) { // 求各位数的立方和
int d = temp % 10;
sum += pow(d, digit);
temp /= 10;
}
if (sum == i) { // 如果是水仙花数
printf("%d ", i);
for (j = i - 1; j >= 100; j--) { // 从水仙花数左边开始找素数
if (is_prime(j)) { // 如果是素数
printf("%d\n", j);
return 0;
}
}
printf("没有找到素数\n");
return 0;
}
}
printf("没有找到水仙花数\n");
return 0;
}
```
程序首先让用户输入一个三位数,然后从这个数的左边开始,找到第一个水仙花数,并找到该水仙花数左边的第一个素数。
程序中定义了一个 `is_prime()` 函数,用于判断一个数是否为素数。程序中使用了循环和条件语句来实现水仙花数和素数的查找。如果找到了水仙花数和素数,程序就输出并退出,否则输出相应的提示信息。
阅读全文