用c语言编写程序:输入两个正整数 m 和 n(1<=m, n<=1000),输出 m 到 n之间的所有满足各位数字的立方和等于它本身的数
时间: 2024-03-23 19:43:21 浏览: 110
好的,以下是用C语言编写的程序,可以实现输入两个正整数 m 和 n(1<=m, n<=1000),输出 m 到 n之间的所有满足各位数字的立方和等于它本身的数。
```c
#include <stdio.h>
int main() {
int m, n;
printf("请输入两个正整数m和n(1<=m, n<=1000):\n");
scanf("%d %d", &m, &n);
for (int i = m; i <= n; i++) {
int num = i, sum = 0;
while (num > 0) {
int digit = num % 10;
sum += digit * digit * digit;
num /= 10;
}
if (sum == i) {
printf("%d\n", i);
}
}
return 0;
}
```
程序中的思路是:遍历m到n之间的所有整数,对于每个整数,将它的各位数字的立方和累加,如果等于它本身,则输出该数。
相关问题
用c语言编写程序:输入2个正整数 m 和 n(1<=m, n<=500),输出 m 和 n 之间的所有素数,每行输出6个。
好的,以下是用C语言编写的程序,可以实现输入2个正整数 m 和 n(1<=m, n<=500),输出 m 和 n 之间的所有素数,每行输出6个。
```c
#include <stdio.h>
#include <stdbool.h>
bool isPrime(int num) {
if (num < 2) {
return false;
}
for (int i = 2; i * i <= num; i++) {
if (num % i == 0) {
return false;
}
}
return true;
}
int main() {
int m, n;
printf("请输入两个正整数m和n(1<=m, n<=500):\n");
scanf("%d %d", &m, &n);
int count = 0;
for (int i = m; i <= n; i++) {
if (isPrime(i)) {
printf("%d\t", i);
count++;
if (count % 6 == 0) {
printf("\n");
}
}
}
return 0;
}
```
程序中用到了一个判断素数的函数`isPrime`,该函数接受一个整数参数`num`,返回一个bool类型的值,表示该整数是否为素数。程序中的主要思路是:遍历m到n之间的所有整数,对于每个整数都调用`isPrime`函数判断是否为素数,如果是,则输出该数并计数,每输出6个数就换行。
用c语言编写代码:输入两个正整数 m 和 n(1<=m, n<=500),统计并输出 m 和 n 之间的素数的个数以及这些素数的和。要求定义并调用函数 prime(m)判断 m 是否为素数
以下是用C语言编写的代码:
```c
#include <stdio.h>
int prime(int num) {
int i;
for(i = 2; i < num; i++) {
if(num % i == 0) {
return 0;
}
}
return 1;
}
int main() {
int m, n, i, count = 0, sum = 0;
printf("请输入两个正整数m和n(1<=m,n<=500):\n");
scanf("%d %d", &m, &n);
if(m > n) {
int temp = m;
m = n;
n = temp;
}
for(i = m; i <= n; i++) {
if(prime(i)) {
count++;
sum += i;
}
}
printf("%d和%d之间的素数个数为:%d,素数的和为:%d\n", m, n, count, sum);
return 0;
}
```
代码中的 `prime` 函数用来判断一个数是否为素数,如果是素数则返回1,否则返回0。主函数中先输入两个正整数 m 和 n,然后用一个循环从 m 到 n 遍历每个数并判断是否为素数,如果是素数则计数器 count 加1,素数和 sum 加上这个素数。最后输出素数个数和素数和。
阅读全文