C Primer Plus第六章编程练习答案

news/2024/11/20 0:33:21/

学完C语言之后,我就去阅读《C Primer Plus》这本经典的C语言书籍,对每一章的编程练习题都做了相关的解答,仅仅代表着我个人的解答思路,如有错误,请各位大佬帮忙点出!

1.编写一个程序,创建一个包含26个元素的数组,并在其中储存26个小 写字母。然后打印数组的所有内容。

#include <stdio.h>
int main(void)
{char ouput[26];for (int i = 0,input = 'a'; input <= 'z';input++,i++){ouput[i] = input;}for (int i = 0; i <26; i++){printf("%c ",ouput[i]);}printf("\n");return 0;
}

2.使用嵌套循环,按下面的格式打印字符:

$

$$

$$$

$$$$

$$$$$

#include <stdio.h>
int main(void)
{for (int i = 0; i < 5; i++){for (int j = 0; j <= i; j++){printf("$");}printf("\n");}return 0;
}

 3.使用嵌套循环,按下面的格式打印字母:

F

FE

FED

FEDC

FEDCB

FEDCBA

注意:如果你的系统不使用ASCII或其他以数字顺序编码的代码,可以 把字符数组初始化为字母表中的字母:

char lets[27] = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";

然后用数组下标选择单独的字母,例如lets[0]是‘A’,等等。

#include <stdio.h>
int main(void)
{int i, j;char c;for (i = 0; i < 6; i++){for (c = 'F',j = 0; j <= i; c--,j++){printf("%c", c);}printf("\n");}return 0;
}

4.使用嵌套循环,按下面的格式打印字母:

A

BC

DEF

GHIJ

KLMNO

PQRSTU

如果你的系统不使用以数字顺序编码的代码,请参照练习3的方案解 决。

#include <stdio.h>
int main(void)
{char c = 'A';for (int i = 0; i < 6; i++){for (int j = 0; j <= i; j++,c++){printf("%c",c);}printf("\n");}return 0;
}

5.编写一个程序,提示用户输入大写字母。使用嵌套循环以下面金字塔 型的格式打印字母: 

         A

       ABA  

     ABCBA

   ABCDCBA

ABCDEDCBA

打印这样的图形,要根据用户输入的字母来决定。例如,上面的图形是 在用户输入E后的打印结果。 提示:用外层循环处理行,每行使用3个内层循环,分别处理空格、以升序打印字母、以降序打印字母。如果系统不使用ASCII或其他以数字顺序 编码的代码,请参照练习3的解决方案。

#include <stdio.h>
int main(void)
{int i, j, num;char input,c = 'A';printf("请输入一个大写字母:");scanf("%c", &input);num = input - 'A' + 1;for (int i = 1; i <= num; i++){for (j = 0; j < num  - i; j++){printf(" ");}for (c = 'A';j < num;c++,j++){printf("%c",c);}for (j = 1,c -= 2; j < i; j++,c--){printf("%c",c);}printf("\n");}return 0;
}

6.编写一个程序打印一个表格,每一行打印一个整数、该数的平方、该 数的立方。要求用户输入表格的上下限。使用一个for循环。

#include <stdio.h>
int main(void)
{int input1 = 0;int input2 = 0;printf("请输入上限:");scanf("%d", &input1);printf("请输入下限:");scanf("%d", &input2);for (int i = input2; i <= input1; i++) {printf("%d\t%d\t%d\n", i, i * i, i * i * i);}return 0;
}

7.编写一个程序把一个单词读入一个字符数组中,然后倒序打印这个单 词。提示:strlen()函数(第4章介绍过)可用于计算数组最后一个字符的下 标。

#include <stdio.h>
#include <string.h>
int main(void)
{char word[20] = "0";printf("请输入以一个单词:");scanf("%s", word);for(int i = strlen(word)-1;i >=0;i--){printf("%c", word[i]);}printf("\n");return 0;
}

8.编写一个程序,要求用户输入两个浮点数,并打印两数之差除以两数 乘积的结果。在用户输入非数字之前,程序应循环处理用户输入的每对值。

#include <stdio.h>
int main(void)
{float f1 = 0.0, f2 = 0.0;printf("请输入两个浮点数:");while (scanf("%f%f", &f1, &f2) == 2){printf("(%.2f-%.2f)/%.2f*%.2f = %.2f\n", f1,f2,f1,f2,(f1-f2)/f1*f2);printf("请输入两个浮点数:");}return 0;
}

9.修改练习8,使用一个函数返回计算的结果。

#include <stdio.h>
float cal(float f1, float f2)
{return (f1 - f2) / f1 * f2;
}
int main(void)
{float f1 = 0.0, f2 = 0.0;printf("请输入两个浮点数:");while (scanf("%f%f", &f1, &f2) == 2){printf("(%.2f-%.2f)/%.2f*%.2f = %.2f\n", f1, f2, f1, f2, cal(f1,f2));printf("请输入两个浮点数:");}return 0;
}

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 <stdio.h>
int main(void)
{int input1 = 0;int input2 = 0;int sum = 0;printf("Enter lower and upper integer limits:");scanf("%d%d", &input1, &input2);while (input1 < input2){sum = 0;for (int i = input1; i <= input2; i++){sum = sum + i * i;}printf("The sums of the squares from %d to %d is %d\n", input1 * input1, input2 * input2, sum);printf("Enter next set of limits:");scanf("%d%d", &input1, &input2);}printf("Done\n");return 0;
}

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

#include <stdio.h>
int main(void)
{int arr[8] = { 0 };for (int i = 0; i < 8; i++){scanf("%d", &arr[i]);}for (int i = 7; i >= 0; i--){printf("%d ", arr[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 <stdio.h>
int main(void)
{int length = 0;double sum = 0.0;printf("请输入一个整型数据:");scanf("%d", &length);while (length > 0){sum = 0.0;for (int i = 1; i < length; i++){sum = sum + 1.0 / i;}printf("1.0 + ... + 1.0 / %d = %lf\n", length, sum);sum = 0.0;for (int i = 1; i <= length; i++){if (i % 2 == 0)sum = sum - 1.0 / i;elsesum = sum + 1.0 / i;}printf("1.0 - ... + 1.0 / %d = %lf\n", length, sum);sum = 0.0;for (int i = 1; i <= length; i++){if (i % 2 != 0)sum = sum + 2 * 1.0 / i;}printf("1.0 + 1.0 + 2.0/3.0... + 1.0 / %d = %lf\n", length, sum);printf("请输入一个整型数据:");scanf("%d", &length);}return 0;
}

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

#include <stdio.h>
int main(void)
{int arr[8] = { 2 };for (int i = 1; i < 8; i++){arr[i] = arr[i - 1] * 2;}int i = 7;do{printf("%d ", arr[i]);}while(i--);return 0;
}

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

#include <stdio.h>
int main(void)
{double d1[8] = { 0.0 };double d2[8] = { 0.0 };double sum = 0.0;printf("请输入第一个数组的8个值:");for (int i = 0; i < 8; i++){scanf("%lf", &d1[i]);}for (int i = 0; i < 8; i++){sum += d1[i];d2[i] = sum;}for (int i = 0; i < 8; i++){printf("%10lf ", d1[i]);}printf("\n");for (int i = 0; i < 8; i++){printf("%10lf ", d2[i]);}printf("\n");return 0;
}

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

#include <stdio.h>
int main(void)
{char ch = '0';char ouput[255] = "0";int i = 0;printf("请输入一行字符:");while ((ch = getchar()) != '\n'){ouput[i++] = ch;}for (int j = i -1; j >= 0; j--){printf("%c", ouput[j]);}printf("\n");return 0;
}

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

#include <stdio.h>
int main(void)
{float Daphne_money = 100.0;float Deirdre_money = 100.0;int count = 0;do{Daphne_money = Daphne_money  + 0.1 * 100.0;Deirdre_money = Deirdre_money * 0.05 + Deirdre_money;count++;} while ((Deirdre_money - Daphne_money) < 0);printf("Daphne_money : %f\tDeirdre_money : %f\n", Daphne_money, Deirdre_money);printf("所需的年数为:%d\n", count);return 0;
}

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

#include <stdio.h>
int main(void) 
{float money = 1000000;int year = 0;while (money >= 0){money = 1.08 * money - 100000;year++;}printf("%d年后Chuckie取完账户的钱\n", year);return 0;
}

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

#include <stdio.h>
int main(void)
{int num = 5;int weeks = 0;while (num <= 150){num = (num - 1) * 2;weeks++;printf("第%d周,Rabnud博士有%d的朋友\n", weeks, num);}return 0;
}


http://www.ppmy.cn/news/89133.html

相关文章

28所示范性微电子院校占地面积排名,中山大学第一!

01中山大学13725 中山大学简称中大&#xff0c;现有广州、珠海和深圳三校区五校园&#xff0c;占地面积共计13725亩。1924年&#xff0c;孙中山亲手将广州地区多所高校整合创立国立广东大学。1926年定名为国立中山大学。如今该校由1952年院系调整后分设的中山大学和中山医科大学…

C++【实现AVL树】

文章目录 一、AVL树的概念及性能二、AVL树结点的创建三、AVL树的插入四、四种旋转&#xff08;1&#xff09;LL-左单旋&#xff08;2&#xff09;RR-右单旋&#xff08;3&#xff09;LR-左右旋&#xff08;4&#xff09;RL-右左旋 五、判断AVL树六、测试结果七、源代码(1) AVL_…

电源大师课-初阶

第一课 电源系统构成和基础原理 1-电源效率 总的Pout除以Pin 2-输出电压调整率 源调整率(输入电压变化时&#xff0c;输出稳定程度) 负载调整率(输出负载变化时&#xff0c;输出稳定度) 温度调整率(工作环境温度在极限情况下&#xff0c;输出的稳定度) 3-纹波测试(20MHz、最…

Day52【动态规划】300.最长递增子序列、674.最长连续递增序列、718.最长重复子数组

300.最长递增子序列 力扣题目链接/文章讲解 视频讲解 1、确定 dp 数组下标及值含义 本题中&#xff0c;正确定义dp数组的含义十分重要 dp[i]&#xff1a;下标 i 表示以 nums[i] 结尾的最长递增子序列&#xff0c;dp[i] 的值表示该子序列长度的 2、确定递推公式 要求 d…

【Flutter 工程】003-钩子函数:Flutter Hooks

【Flutter 工程】003-钩子函数&#xff1a;Flutter Hooks 文章目录 【Flutter 工程】003-钩子函数&#xff1a;Flutter Hooks一、概述1、前言2、Flutter Hooks 概述 二、useState 基本使用0、计数器官方 demo1、安装 flutter_hooks2、代码改造3、运行结果4、神奇的事情 三、使用…

HTTP中 Connection: keep-Alive与TCP中中keepalive有什么区别?

有小伙伴不明白keep-Alive和keepalive有什么区别&#xff1f;今天写这篇文章详细讲清楚&#xff01; HTTP是请求响应模型也就是客户端发起了请求&#xff0c;服务端才会返回响应&#xff0c;一来一回。 由于 HTTP 是基于 TCP 传输协议实现的&#xff0c;客户端与服务端要进行 H…

RESTful API介绍

RESTful API&#xff08;Representational State Transfer&#xff09;是一种设计 Web 应用程序的架构风格&#xff0c;它使用 HTTP 请求来进行数据传输和交互。 RESTful API 的核心思想是将资源&#xff08;比如用户、订单、产品&#xff09;作为 Web 上的唯一标识&#xff0…

公文写作素材:为人处世类过渡句50例

1.身处逆境&#xff0c;敢于亮剑&#xff0c;坚毅前行&#xff0c;方能逆势突围&#xff1b;面对困难&#xff0c;坚定信心&#xff0c;敢拼敢闯&#xff0c;定能笑到最后。 2.没有海纳百川的胸怀&#xff0c;怎能容得下不同性格的人&#xff1b;没有从善如流的雅量&#xff0…