新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
#include stdio.h
十年专注成都网站制作,成都定制网页设计,个人网站制作服务,为大家分享网站制作知识、方案,网站设计流程、步骤,成功服务上千家企业。为您提供网站建设,网站制作,网页设计及定制高端网站建设服务,专注于成都定制网页设计,高端网页制作,对成都报废汽车回收等多个方面,拥有多年的网站设计经验。
unsigned int func(unsigned int n)
{
return (n == 1)? 1 : n * func(n-1);
}
int main(void)
{
unsigned int n = 0, rval = 0;
printf("Input data:");
scanf("%u", n);
if (n == 0)
{
printf("Input error.\n");
return -1;
}
rval = func(n);
printf("%u!=%u\n", n, rval);
return 0;
}
你声明的sum函数是没有参数的,你调用时,又给他了参数,所以报sum函数参数调用错误
另外,你的函数实现也有问题,修改一下:
#include "stdio.h"
int pl(int n);
int sum(int n);
void main()
{
int x,y,z,m;
scanf("%d",m)
x=pl(m);
y=sum(m);
printf("x=%d\n",x);
printf("y=%d\n",y);
}
int pl(int n)//求1*2*3*4*..*n
{
if(n==1)
return 1;
else
return pl(n-1)*n;
}
int sum(int n) //求1+2+3+...+n
{
if(n==1)
return 1;
else
return sum(n-1)+n;
}
1、首先本题的思路已经给出,要求用递归算法。
2、程序源代码如下:
#includestdio.h
int sum(int n);
int main()
{
int i=100;
printf("1~%d的和为:\n",i);
printf("%d\n",sum(100));
return 0;
}
//下面是一个递归求和函数
int sum(int n)
{
if (n==1)
return 1;
else
return n+sum(n-1);
}
3、程序的输出结果如下:
#include iostream
#include iomanip
using namespace std;
int add(int n);
int main()
{
int i=100;
int b;
b=add(100);
coutbendl;
}
int add(int n)
{
if(n==1)
return 1;
else
return n+add(n-1);
},利用add()函数进行递归,这是个从1加到n的递归函数
C语言:递归求和求f(n)的值可以采用以下的代码:
#includestdio.h
int sum(int n)
{
if(!n)
return 0;
else
return n + sum(n - 1);
}
int main()
{
int n;
scanf("%d",n);
printf("%d\n",sum(n));
return 0;
}
扩展资料:
数学函数
char *ecvt(double value,int ndigit,int *decpt,int *sign),将浮点数value转换成字符串并返回该字符串
char *fcvt(double value,int ndigit,int *decpt,int *sign),将浮点数value转换成字符串并返回该字符串
char *gcvt(double value,int ndigit,char *buf),将数value转换成字符串并存于buf中,并返回buf的指针
char *ultoa(unsigned long value,char *string,int radix),将无符号整型数value转换成字符串并返回该字符串,radix为转换时
double _matherr(_mexcep why,char *fun,double *arg1p,double *arg2p,double retval),用户修改数学错误返回信息函数(没有必要使用)
unsigned int _clear87() 清除浮点状态字并返回原来的浮点状态
void _fpreset() 重新初使化浮点数学程序包
unsigned int _status87() 返回浮点状态字
参考资料来源:百度百科-C语言函数
#include "stdio.h"
int sum(int n){
if(n==1)
return 1;
return n+sum(n-1);
}
int main(void){
int k;
while(1){
printf("Input k(int 0k=10000)...\nk=");
if(scanf("%d",k) k0 k=10000){
printf("The sum of them is %d\n",sum(k));
break;
}
printf("Error, must be 0k=10000: ");
fflush(stdin);
}
return 0;
}