11. 求 ∑n!(即求1!+ 2!+ 3!+ 4!+ …… + 20!).
#include <stdio.h>
int main()
{
int n,Sn,Sn1,i;
Sn=1;Sn1=0;
printf("求 ∑n!,输入n的值:");
scanf("%d",&n);
for(i=1;i<=n;i++)
{
Sn=Sn*i;
Sn1+=Sn;
}
printf("∑%d!=%d\n",n,Sn1);
return 0;
}
12. 一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如,6的因子为1, 2, 3,而6 = 1 + 2 + 3,因此6是“完数”。编程序找出1000之内的所有完数,并按下面格式输出其因子:6 its factors are 1, 2, 3
#include<stdio.h>
void main()
{
int i,j,sum;
for(i=2;i<=1000;i++)
{
sum=0;
for(j=1;j<i;j++)
{
if(i%j == 0)
sum+=j;
}
if(i==sum)
{
printf("%d its factors are ", i);
for (j = 1; j < i; j++)
{
if (i%j == 0)
printf("%d,", j);
}
printf("\n");
}
}
}
13.一个球从100m高度自由落下,每次落地后反弹回原来高度的一半,再落下,再反弹。求它在第10次落地时共经过多少米,第10次反弹多高。
#include<stdio.h>
int main()
{
float hight=100;
float a,s=0;
for(a=1;a<=10;a++)
{
s=s+(hight*3/2);
hight=hight/2;
}
printf("第十次落地时共经历%f米\n 第十次反弹%f米\n",s,hight);
return 0;
}
14.12.猴子吃桃问题。猴子第一天摘下若干个桃子,当即吃了一半,好不过瘾,又多吃了一个。第二天早上又吃了剩下的桃子的一半,又多吃了一个。以后每天都吃了前一天剩下的一半零一个,到第10天早上想再吃的时候,就剩下一个桃子。求第一天共摘多少个桃子。
#include<stdio.h>
int main()
{
int i,n;
i=1;
for(n=4;n>1;n--)
{
i=2*(i+1);
}
printf("第一天一共摘了:%d个桃子\n",i);
return 0;
}
15.迭代法求a平方根。已知求平方根的迭代公式为:x n + 1 = (xn + a / xn) / 2要求前后两次求出的差的绝对值小于10 - 5。
#include<stdio.h>
#include<math.h>
int main()
{
float x1 = 1, x2, a;
printf("请输入 a的值:");
scanf("%f", &a);
x2 = a;
while (fabs(x1 - x2) >= 10-5)
{
x1 = x2;
x2 = (x1 + a / x1) / 2;
}
printf("%f,%f", x1, x2);
return 0;
}