5.1:
#include <stdio.h>
#include <genlib.h>
#include <math.h>
main()
{
double fait;
printf("显示常量Φ,即黄金比例。\n");
fait=(1.0+sqrt(5.0))/2.0;
printf("Φ=%.2f\n",fait);
}
5.2
//就方程式的根
#include <stdio.h>
#include <genlib.h>
#include <math.h>
#include <simpio.h>
main()
{
double a,b,c;
printf("请输入方程式的三个参数A,B,C:\n");
printf("a:");
a=GetReal();
if (a==0)
printf("a的值不能为0 ,请重新输入...\n");
printf("a:");
a=GetReal();
printf("b:");
b=GetReal();
printf("c:");
c=GetReal();
if (b*b-4*a*c>=0)
{
printf("第一个根是:%f\n",(-b+sqrt(b*b-4*a*c))/2*a);
printf("第二个根是:%f\n",(-b-sqrt(b*b-4*a*c))/2*a);
}
else
{
printf("该方程无解!\n");
}
}
5.3
#include <stdio.h>
#define LowerLimit
32
#define UpperLimit 100
#define StepSize
2
double FahrenheitToCelsius(double f);
main()
{
int f;
printf("Fahrenheit to Celsius Table.\n");
printf("
F
C\n");
for(f=LowerLimit;f<=UpperLimit;f+=StepSize)
{
printf("=
%3.1f\n",f,FahrenheitToCelsius(f));
}
}
double FahrenheitToCelsius(double f)
{
return ((f-32)*5.0/9.0);
}
5.5
#include <stdio.h>
#include <genlib.h>
int RaiseInToPower(int n,int k);
main()
{
int k;
printf("显示2的K次方,k从0~10:\n");
printf("
K
Power\n");
for (k=0;k<=10;k++)
{
printf("
=
M \n",k,RaiseInToPower(2,k));
}
}
int RaiseInToPower(int n,int k)
{
int i,p=1;
switch(k)
{
case 0:
p=1;
break;
default:
for (i=1;i<=k;i++)
{
p*=n;
}
}
return (p);
}
5.6
#include <stdio.h>
#include <genlib.h>
double RaiseRealToPower(double n,int k);
main()
{
int k;
printf("显示10的K次方,k从-4~4:\n");
printf("---------------------------\n");
printf("
K
Power\n");
for (k=-4;k<=4;k++)
{
if (k<0)
{
printf("
=
%.4f \n",k,RaiseRealToPower(10,k));
}
else
{
printf("
= %8.1f \n",k,RaiseRealToPower(10,k));
}
}
}
double RaiseRealToPower(double n,int k)
{
int i;
double p=1;
if (k>0)
{
for (i=1;i<=k;i++)
{
p*=n;
}
}
else if (k==0)
{
p=1;
}
else
{
for (i=k;i<0;i++)
{
p*=n;
}
p=1/p;
}
return (p);
}