C语言编程 输入20个数 用递归法计算并输出所有正数的和

供稿:hz-xin.com     日期:2025-01-13
C语言问题 编程实现从键盘输入20个整数,统计其中正整数的个数,并计算输出所有正整数之和。

#include
void main()
{
int a[20],sum=0,count=0;
printf("请输入20个整数
");
for (int i=0;i<20;i++)
{
scanf("%d",&a[i]);
if(a[i]>0)
{
sum=sum+a[i];
count++;
}
}
printf("正整数的和为%d
正整数的个数为%d
",sum,count);
}

#include
int main()
{
int a[80],i,b=0;
for(i=0;i<=80;i++)
{scanf("%d",&a[i]);
if (a[i]>0) b=b+a[i];
else break;}
printf("%d",b);
}

//呵呵,这个是我自己写的,绝对是递归
//digui返回类型可以根据情况自己改为int,long int,long long int

#include<stdio.h>

//主函数
int main(void)
{
//递归函数声明
int digui(int sum,int count);
int sum=0;int count=0;int result;
while(1)
{
printf("请输入20个整数(每次输入后回车):\\\n");
//调用
result=digui(sum,count);
printf("%d\n",result);
}
return 0;

}

//递归函数
int digui(int sum,int count)
{
int n;

if(count==20)
return sum;

else
{
scanf("%d",&n);
if(n>0)
return digui(sum+n,count+1);
else
return digui(sum,count+1);
}
}

#include <iostream>
using namespace std;
int main()
{
int a[20],i,sum=0;
for(i=0;i<20;i++)
cin>>a[i];
for(i=0;i<20;i++)
if(a[i]>0)
sum+=a[i];
cout<<a[i];
return 0;
}

include "stdio.h"
void main()
{
int a[20],i,sum=0;
for(i=0;i<20;i++)
{
scanf("%d",&a[i]);
}
for(i=0;i<20;i++)
{
sum=sum+a[i];
}
printf("结果:%d\n",sum);
}

//---------------------------------------------------------------------------

#include <stdio.h>

long int sum(int count)/*递归函数,返回输入的count个数字中的正整数之和*/
{
if (count) {
int s=0;
scanf("%d",&s);
return s>0?s+sum(count-1):sum(count-1);
}
else return 0;
}
int main(void)
{
long int s=sum(20);

printf("%ld\n",s);
return 0;
}
//---------------------------------------------------------------------------

C语言编程 输入20个数 用递归法计算并输出所有正数的和
\/\/digui返回类型可以根据情况自己改为int,long int,long long int include<stdio.h> \/\/主函数 int main(void){ \/\/递归函数声明 int digui(int sum,int count);int sum=0;int count=0;int result;while(1){ printf("请输入20个整数(每次输入后回车):\\\\\\n");\/\/调用 result=digui(sum...

c语言递归程序 将1到20 这20个数字放到一个环上 环上任意两个相邻数字之...
include <memory.h> define N 20 \/\/环的长度 define M (N<<1) \/\/质数表的长度 char cycle[N]; \/\/环 char prime[M]; \/\/质数表 void Prime ( void ) \/\/用筛选法生成质数表 { int i, j, k;memset ( prime, 1, sizeof(prime) );i = 2;prime[i] = 0;while ( i < M ){...

初学C语言菜鸟求助:计算斐波那契数列的前20项(要求用递归法)
for(k=1;k<=20;k++){ printf(" %-10d",Fibonacci(k)); \/\/数字左对齐效果,可以查看书本关于printf函数的输出格式 if(k%4==0)printf("\\n"); \/\/每行显示四个数字,可视化效果好些 } return 0;}

...最后把数组作为参数传递给add函数,求这20个数的和并显示
printf("%d\\n",add(a,20));}

c语言解答:用递归方法求费波纳茨数列第20项的数。
include <stdio.h>int fib(int x) { if (x == 1) { return 1; } else if (x == 0) { return 0; } else { return fib(x-1)+fib(x-2); }}int main() { printf("%d\\n", fib(20);}

用C语言编程:用递归的方法求 f(n) = 1*1 + 2*2 + 3*3 +……+ n*n...
include"stdio.h"int f(int n){ if (n)return n*n+f(n-1);else return 0;} void main(){ int n;scanf("%d",&n);printf("%d",f(n));}

求一组C语言编程。编写一个函数,用递归的方法求1+2+3+4+...+n的值...
include<stdio.h>#include<stdlib.h>int fun(int x){ if(x==1) return 1; else return( x + f(x-1));}int main(){ int n; scanf("%d",&n); printf("%d",f(n)); return 0;}

利用C语言求阶乘 例如求20! 用循环和函数两种方法……
printf("===用递推法求阶乘===\\n"); printf("请输入正整数n: "); \/\/输入n,求n! scanf("%d",&n); a[0]=1; \/\/初始化,1的阶乘是1位 a[1]=1; \/\/1!的值为1 printFactorial(a,1); \/\/打印它的结果 for (k=2;k<=n;k++) { factorial(a,k); \/\/利用上次的结果来求k! print...

输入一个正整数 用递归实现将整数逐位正序输出每一位数(c语言)
include <stdio.h>void f(int a){ if (a < 10) printf("%d", a); else { f(a\/10); printf("%d", a%10); }}int main(){ int a; printf("a = "); scanf("%d", &a); f(a); getchar(); return 0;} ...

c语言:用递归方法编写程序,求n阶勒让德多项式的值
c语言编程:使用递归方法实现求解n阶勒让德多项式的程序。首先定义了legendre函数,该函数接收两个整数参数n和x,递归地计算并返回勒让德多项式的值。如果n等于0,则返回1;如果n等于1,则返回x;否则,使用递归公式计算结果。在主函数中,用户被提示输入n和x的值,然后调用legendre函数计算并输出Pn(x...