求和
求和训练
题目描述
求以下三数的和,保留2位小数 1~a之和 1~b的平方和 1~c的倒数和
输入
a b c
输出
1+2+…+a + 12+22+…+b^2 + 1/1+1/2+…+1/c
样例输入
100 50 10
样例输出
47977.93
#include"stdio.h"
int main()
{
double a,b,c,sum1=0,sum2=0,sum3=0,i,sum=0;
scanf("%lf",&a);
scanf("%lf",&b);
scanf("%lf",&c);
for(i=1;i<=a;i++)
{
sum1+=i;
}
for(i=1;i<=b;i++)
{
sum2+=i*i;
}
for(i=1;i<=c;i++)
{
sum3+=1.0/i;
}
sum=sum1+sum2+sum3;
printf("%.2lf",sum);
return 0;
}
注意前面用double定义后面输出就得用%lf。
#include <stdio.h>
int main()
{
long double N, sum = 0;
int factor[100], x = 0;
scanf( "%Lf", &N );
for ( int i = 6; i <= N; i++ )
{
if ( i % 10 == 6 || i % 10 == 8 )
{
for ( int j = 1; j <= i / 2; j++ )
{
if ( i % j == 0 )
{
factor[x] = j;
x++;
sum = sum + j;
}
}
if ( sum == i )
{
printf( "%d its factors are ", i );
for ( int k = 0; k < x; k++ )
{
printf( "%d ", factor[k] );
}
printf( "\n" );
}
sum = 0;
x = 0;
}
}
return(0);
}
解题思路:
输入一个数N,循环判断,从i=2到N的每一个数;
如果是完数,则输出;
判断方法,定义j为因子(1到N-1),若i%j==0,则是它的因子;
判断期间把所有因子的和(sum)求出来;
最后和(sum)等于i则是完数;
注意事项:
每次判断完,一个数i后,要把sum置0;
按输出规则输出;