这是一个C语言 while 循环的示例,已知有下面的数列:
现在任意给出一个整数 k(1≤k≤15),要求计算出一个最小的 n,使得 Sn>k。
输入:一个整数k(1≤k≤15)。
输出:最小的n。
本题算法非常简单,只要按照已知公式
反复累加,直到 Sn 的值大于给定的整数 k,输出当前的 n 即可。
另外,考虑到 k 的最大值是 15,因而将 n 定义为 long int 型,反复累加的和 Sn 定义为 long double 型。
代码清单 1:使用 while 语句
#include <stdio.h>
#include <stdlib.h>
int main( )
{
int k;
long int n = 0;
long double Sn = 0;
printf("输入一个整数");
printf("(1-15):\n");
scanf("%d",&k);
while(Sn <= k)
{
n++;
Sn += 1.0 / n;
}
printf("最小的n是");
printf("%ld\n",n);
system("pause");
return 0;
}
运行结果为:
输入一个整数(1-15):
8
最小的n是1674
代码清单 2:使用 do-while 语句
#include <stdio.h>
#include <stdlib.h>
int main( )
{
int k;
long int n = 0;
long double Sn = 0;
printf("输入一个整数");
printf("(1-15):\n");
scanf("%d",&k);
do
{
n++;
Sn += 1.0/n;
}while(Sn <= k);
printf("最小的n是");
printf("%ld\n",n);
system("pause");
return 0;
}
运行结果:
输入一个整数(1-15):
5
最小的n是83