#include <stdio.h>
int main()
{
int a=2, n=1,sum=1;
while (n<=50)
{
n=n+1;
sum=sum*a;
a=a+2;
}
printf("%d %d\n",n,a);
printf("%d\n",sum);
return 0;
}
以上为错解,运行结果:n=51,a=102,sum=0
错误原因:算出的结果sum过大,使得int爆了
解决方法:将sum初始值搞成double类型的
#include <stdio.h>
int main()
{
double sum=1;
int a=2, n=1;
while (n<=50)
{
n=n+1;
sum=sum*a;
a=a+2;
}
printf("%d %d\n",n,a);
printf("%lf\n",sum);
return 0;
}
值得注意的是改数据类型(例:此文中int变double类型时)也要改相对应的格式字符
以下为常用格式字符
1.% d 格式符用来输出十进制整数
2.% c 格式符,用来输出一个字符。
3.% s 格式符,用来输出一个字符串。
4.% o 格式符,以八进制整型式输出整数。
5.%×格式符,以十六进制数形式输出整数。
6.% u 格式符,用来输出 unsigned 型数据,即无符号数,以十进制形式输出。
7.% f 格式符,用来输出实数(包括单双精度),以小数形式输出。
8.% e 格式符,以指数形式输出实数。
9.% g 格式符,用来输出实数,它根据数值的大小,自动选 f 格式或 e 格式(选择输出是占宽度较小的一种),且不输出无意义的零。
10.% p 格式符,用于变量地址的输出。
11.% d ,按整型数据的实际长度输出。
12.% md , m 为指定的输出字段的宽度。
13.% ld ,输出长整型数据。 %12ld%12ld"输出两个12位的长整数