函数的应用,用函数的方法解决下列问题

本文通过四个具体的C语言程序示例介绍了如何寻找指定区间内的素数、筛选特定条件下的整数、找出所有水仙花数以及使用递归方法计算阶乘。这些示例覆盖了从简单循环到递归调用等不同难度级别的算法实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.打印输出600-800间的全部素数

#include<stdio.h>
int prime(int num)
{
	int flag=1,n;
    for (n=2;n<=num/2&&flag==1;n++)
    if(num%n==0)
	flag=0;
  return (flag);
}
int main()
{
	int prime(int num);
	int num;
	for(num=600;num<=800;num++)
	{
	if(prime(num))
	printf("%5d",num);
    }
	return 0;
}

2.求1000以内既能被7整除又能被9整除,且各个位上的数字都为奇数的整数

#include<stdio.h>
int S(int x)
{   
		if(x%7==0&&x%9==0&&x/100%2==1&&x/10%10%2==1&&x%10%2==1)
	{
    	return 1;
		
    }
	return 0;
}
int main()
{
	int S(int x);
	for (int x=1;x<=1000;x++)
	{
    if(S(x)==1)
    printf("%d\n",x);
	}
		return 0;
}

3.打印所有的水仙花数

#include<stdio.h>
int S(int x)
{
   int a,b,c;
   c=x/100;
   b=x/10%10;
   a=x%10;
   if(x==a*a*a+b*b*b+c*c*c)
   return 1;
   else
   return 0;
}
int main()
{
	int S(int x);
	int x;
	for(x=100;x<=999;x++)
	{
		if(S(x)==1)
		printf("%d\n",x);
	}
	return 0;
}

4.递归方法计算20!

#include<stdio.h>
int main()
{
	double S(int n);
	printf("%e\n",S(20));
}
double S(int n)
{
	if(n>1)
	return n*S(n-1);
	else
	return 1;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值