C Primer Plus第六版 第六章编程练习10~18

C Primer Plus第六版 第六章编程练习10~18,第1张

C Primer Plus第六版 第六章编程练习10~18

10.编写一个程序,要求用户输入一个上限整数和一个下限整数,计算从上限到下限范围内所有 整数的平方和,并显示计算结果。然后程序继续提示用户输入上限和下限整数,并显示结果,直到 用户输入的上限整数等于或小于下限整数为止。程序的运行示例如下:

Enter lower and upper integer limits: 5 9

The sums of the squares from 25 to 81 is 255

Enter next set of limits: 3 25

The sums of the squares from 9 to 625 is 5520

Enter next set of limits: 5 5

Done

#include 
int main(void)
{
int lower,upper,i;
long sum=0;

printf("Enter lower and upper integer limits:");
while((scanf("%d %d",&lower,&upper)==2)&&lower 

11.编写一个程序,在数组中读入8个整数,然后按倒序打印这8个整数。

#include 
int main(void)
{
int a[8];
int i;

printf("Enter 8 integers:n");
for(i=0;i<8;i++)
scanf("%d",&a[i]);
printf("Print the integers inverted order:n");
for(i=7;i>=0;i--)
printf("%d ",a[i]);
printf("n");

return 0;
}

12.考虑下面两个无限序列:

1.0 + 1.0/2.0 + 1.0/3.0 + 1.0/4.0 + ...

1.0 - 1.0/2.0 + 1.0/3.0 - 1.0/4.0 + ...

编写一个程序计算这两个无限序列的总和,直到到达某次数。提示:奇数个-1相乘得-1,偶数个-1 相乘得1。让用户交互地输入指定的次数,当用户输入0或负值时结束输入。查看运行100 项、 1000项、10000项后的总和,是否发现每个序列都收敛于某值?

#include 
int main(void)
{
int i,j;
int k=-1;
double sum1,sum2=0;

printf("Enter the items(<=0 to quit):n");
while((scanf("%d",&i)==1)&&i>0)
{
for(j=1;j<=i;j++)
{
sum1+=1.0/j;
k*=-1;
sum2+=k*(1.0/j);
}
printf("%d items sum1=%lfn",i,sum1);
printf("%d items sum2=%lfn",i,sum2);
sum1=sum2=0;
k=-1;
printf("Enter the items(<=0 to quit):n");
}
printf("Done.n");

return 0;
}

运行结果:

Enter the items(<=0 to quit):
4
4 items sum1=2.083333
4 items sum2=0.583333
Enter the items(<=0 to quit):
100
100 items sum1=5.187378
100 items sum2=0.688172
Enter the items(<=0 to quit):
1000
1000 items sum1=7.485471
1000 items sum2=0.692647
Enter the items(<=0 to quit):
10000
10000 items sum1=9.787606
10000 items sum2=0.693097
Enter the items(<=0 to quit):

可看出,只有第二个序列收敛于某值。

13.编写一个程序,创建一个包含8个元素的int类型数组,分别把数组元素设置为2的前8次幂。使用for循环设置数组元素的值,使用do while循环显示数组元素的值。

#include 
int main(void)
{
int a[8];
int i=0;

for(a[0]=1,i=1;i<8;i++)
a[i]=a[i-1]*2;
i=0;
do
{
printf("%dn",a[i]);
i++;
}while(i<8);

return 0;
}

14.编写一个程序,创建两个包含8个元素的double类型数组,使用循环提示用户为第一个数组输入8个值。第二个数组元素的值设置为第一个数组对应元素的累积之和。例如,第二个数组的第4 个元素的值是第一个数组前4个元素之和,第二个数组的第5个元素的值是第一个数组前5个元素之和(用嵌套循环可以完成,但是利用第二个数组的第5个元素是第二个数组的第4个元素与第一个 数组的第5个元素之和,只用一个循环就能完成任务,不需要使用嵌套循环)。最后,使用循环显示两个数组的内容,第一个数组显示成一行,第二个数组显示在第一个数组的下一行,而且每个 元素都与第一个数组各元素相对应。

#include 
int main(void)
{
double x[8],y[8];
int i;

printf("Enter 8 double numbers:n");
for(i=0;i<8;i++)
scanf("%lf",&x[i]);
for(i=0,y[i]=0;i<8;i++)
y[i]+=(y[i-1]+x[i]);
for(i=0;i<8;i++)
printf("%-10lf",x[i]);
printf("n");
for(i=0;i<8;i++)
printf("%-10lf",y[i]);
printf("n");

return 0;
}

15.编写一个程序,读取一行输入,然后把输入的内容倒序打印出来。可以把输入储存在char类型 的数组中,假设每行字符不超过255。回忆一下,根据%c转换说明,scanf()函数一次只能从输入 中读取一个字符,而且在用户按下Enter键时scanf()函数会生成一个换行字符(n)。

#include 
#define SIZE 255
int main(void)
{
char ch[SIZE];
int i,j;
i=0;

while((scanf("%c",&ch[i])!=EOF)&&i=0;j--)
printf("%c",ch[j]);
printf("n");

return 0;
}

注:C把输入输出当作文件来处理,EOF代表文件末尾,在Windows中,用CTRL+Z表示。

16.Daphne以10%的单利息投资了100美元(也就是说,每年投资获利相当于原始投资10%)。Deirdre以5%的复合利息投资了100美元(也就是说,利息是当前余额的5%,包含之前的利息)。 编写一个程序,计算需要多少年Deirdre的投资额才会超过Daphne,并显示那时两人的投资额。

#include 
int main(void)
{
int years=0;
double x=100.0;
double y=100.0;

do
{
x+=10.0;
y+=(y*0.05);
years++;
}while(y 

17.Chuckie Lucky赢得了100万美元(税后),他把奖金存入年利率8%的账户。在每年的最后一天,Chuckie取出10万美元。编写一个程序,计算多少年后Chuckie会取完账户的钱?

#include 
int main(void)
{
double x=1000000;
int years=0;

do
{
x+=x*0.08;
x-=100000;
years++;
}while(x>0);
printf("%d years later,Chuckie will get off all the money.n",years);

return 0;
}

18.Rabnud博士加入了一个社交圈。起初他有5个朋友。他注意到他的朋友数量以下面的方式增长。第1周少了1个朋友,剩下的朋友数量翻倍;第2周少了2个朋友,剩下的朋友数量翻倍。一般而言,第N周少了N个朋友,剩下的朋友数量翻倍。编写一个程序,计算并显示Rabnud博士每周 的朋友数量。该程序一直运行,直到超过邓巴数(Dunbar's number)。邓巴数是粗略估算一个人 在社交圈中有稳定关系的成员的最大值,该值大约是150。

#include 
#define Dunbar 150
int main(void)
{
int weeks=0;
int friends=5;

while(friends<=Dunbar)
{
weeks++;
friends-=weeks;
friends*=2;
printf("%d weeks later,Rabund's friends' number is %d.n",weeks,friends);
}
printf("%d weeks later,Rabund's friends's number will catch over Dunbar's number.n",weeks);

return 0;
}

欢迎分享,转载请注明来源:内存溢出

原文地址:https://www.54852.com/zaji/5670713.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-12-16
下一篇2022-12-16

发表评论

登录后才能评论

评论列表(0条)

    保存