C Primer Plus 第四章 课后答案
目录
1.再次运行程序清单 4.1,但是在要求输入名时,请输入名和姓(根据英文书写习惯,名和姓中间有一个空格),看看会发生什么情况?为什么?
2.假设下列示例都是完整程序中的一部分,它们打印的结果分别是什么?
3.在第2题的c中,要输出包含双引号的字符串Q,应如何修改?
9.分别写出读取下列各输入行的scanf()语句,并声明语句中用到变量和数组
1.编写一个程序,提示用户输入名和姓,然后以“名,姓”的格式打印出来
3.编写一个程序,读取一个浮点数,首先以小数点记数法打印,然后以指数记数法打印。用下面的格式进行输出(系统不同,指数记数法显示的位数可能不同):
4.编写一个程序,提示用户输入身高(单位:英寸)和姓名,然后以下面的格式显示用户刚输入的信息:
6.编写一个程序,先提示用户输入名,然后提示用户输入姓。在一行打印用户输入的名和姓,下一行分别打印名和姓的字母数。字母数要与相应名和姓的结尾对齐,如下所示:
接下来,再打印相同的信息,但是字母个数与相应名和姓的开头对齐,如下所示: Melissa Honeybee
复习题
1.再次运行程序清单 4.1,但是在要求输入名时,请输入名和姓(根据英文书写习惯,名和姓中间有一个空格),看看会发生什么情况?为什么?
程序不能正常运行,第一个scanf语句只读入姓,而用户输入的姓仍留在输入缓冲区中,下一条scanf语句读入。而整型输入无法读取字符串输入,导致读取失败。
2.假设下列示例都是完整程序中的一部分,它们打印的结果分别是什么?
a.He sold the painting for $%234.50.
b.Hi!
c.
His Hamlet was funny without being vulgar.
has 42 characters.
d.Is 1.20e+003 the same as 1201.00?
3.在第2题的c中,要输出包含双引号的字符串Q,应如何修改?
printf("\"%s\"\nhas %d characters.\n", Q, strlen(Q));
4.找出下面程序中的错误
define B booboo
define X 10
main(int)
{
int age;
char name;
printf("Please enter your first name.");
scanf("%s", name);
printf("All right, %c, what's your age?\n", name);
scanf("%f", age);
xp = age + X;
printf("That's a %s! You must be at least %d.\n", B, xp);
rerun 0;
}
#define B "booboo"
#define X 10
int main(void)
{
int age;
char name[15];
printf("Please enter your first name.");
scanf("%s", name);
printf("All right, %s, what's your age?\n", name);
scanf("%d", &age);
int xp = age + X;
printf("That's a %s! You must be at least %d.\n", B, xp);
return 0;
}
5.假设一个程序的开头是这样:
#include <stdio.h>
#include <stdlib.h>
#define BOOK "War and Peace"
int main(void)
{
float cost = 12.99;
float percent = 80.0;
printf("This copy of \"%s\" sells for $%2.2f.\n" "That is %2.0f%% of list.\n", BOOK, cost, percent);
}
6.打印下列各项内容要分别使用什么转换说明?
a.%d
b.%4x
c.%10.3f
d.%12.2e
c.%-30s
7.打印下面各项内容要分别使用什么转换说明?
a.%15lu
b.%4x
c.%-12.2e
d.%+10.3f
e.%8.8s
8.打印下面各项内容要分别使用什么转换说明?
a.%6.4d
b.%*o
c.%2c
d.%+.2f
e.%-7.5s
9.分别写出读取下列各输入行的scanf()语句,并声明语句中用到变量和数组
a.
int a;
scanf("%d", &a);
b.
float b1, b2;
scanf("%f %f", &b1, &b2);
c.
char c[30];
scanf("%s", c);
d.
char d1[15];
int d2;
scanf("%s %d");
e.
int e;
scanf("%*s %d", &e);
10.什么是空白?
包括:空格、制表符和换行符
C语言用空白分隔记号
scanf()使用空格分隔连续的输入项
11.下面的语句有什么问题?如何修正?
printf("The double type is %zd bytes..\n", sizeof(double));
z为修饰符,不是转换符
12.假设要在程序中用圆括号代替花括号,以下方法是否可行?
可以,但编译器无法识别哪些该换哪些不该换,所有的()都会被替换为{}
编程练习
1.编写一个程序,提示用户输入名和姓,然后以“名,姓”的格式打印出来
#include <stdio.h>
#include <stdlib.h>
int main()
{
char fn[15], ln[15];
printf("input fn and ln:");
scanf("%s %s", fn, ln);
printf("%s\n", fn);
printf("%s\n", ln);
}
2.编写一个程序,提示用户输入名和姓,并执行一下操作:
#include <stdio.h>
#include <stdlib.h>
int main()
{
char n[30];
printf("input fn and ln:");
scanf("%s", n);
printf("\"%s\"\n", n);
printf("\"%20s\"\n", n);
printf("\"%-20s\"\n", n);
}
3.编写一个程序,读取一个浮点数,首先以小数点记数法打印,然后以指数记数法打印。用下面的格式进行输出(系统不同,指数记数法显示的位数可能不同):
a.
21.299999 2.130000e+001
21.000000 2.100000e+001
b.
21.290001 2.129000e+001
21.290001 2.129000e+001
4.编写一个程序,提示用户输入身高(单位:英寸)和姓名,然后以下面的格式显示用户刚输入的信息:
#include <stdio.h>
#include <stdlib.h>
int main()
{
float a;
char n[30];
printf("input ur h(cm) and name:");
scanf("%f %s", &a, n);
printf("%s, u'r %.2f meters tall\n", n, a / 100);
}
5.编写一个程序,提示用户输入以兆位每秒(Mb/s)为单位的下载速度和以兆字节(MB)为单位的文件大小。程序中应计算文件的下载时间。注意,这里1字节等于8位。使用float类型,并用/作为除号。该程序要以下面的格式打印 3 个变量的值(下载速度、文件大小和下载时间),显示小数点后面两位数字:
#include <stdio.h>
#include <stdlib.h>
int main()
{
float a, b;
scanf("%f %f", &a, &b);
printf("At %.2f megabits per second, a file of %.2f megabytes\ndownloads in %.2f seconds.\n", a, b, b/a);
}
6.编写一个程序,先提示用户输入名,然后提示用户输入姓。在一行打印用户输入的名和姓,下一行分别打印名和姓的字母数。字母数要与相应名和姓的结尾对齐,如下所示:
Melissa Honeybee
7 8
接下来,再打印相同的信息,但是字母个数与相应名和姓的开头对齐,如下所示: Melissa Honeybee
7 8
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
char fn[15], ln[15];
printf("input fn:");
scanf("%s", fn);
printf("input ln:");
scanf("%s", ln);
int fl = strlen(fn);
int ll = strlen(ln);
printf("%s %s\n", fn, ln);
printf("%*d %*d\n", fl, fl, ll, ll);
printf("%s %s\n", fn, ln);
printf("%*d %*d\n", -fl, fl, -ll, ll);
//在输出中%*d中的*代表格式化参数,可以有型如%*.*d这样的操作
}
7.编写一个程序,将一个double类型的变量设置为1.0/3.0,一个float类型的变量设置为1.0/3.0。分别显示两次计算的结果各3次:一次显示小数点后面6位数字;一次显示小数点后面12位数字;一次显示小数点后面16位数字。程序中要包含float.h头文件,并显示FLT_DIG和DBL_DIG的值。1.0/3.0的值与这些值一致吗?
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
double d = 1.0 / 3.0;
float f = 1.0 / 3.0;
printf("%.6lf %.6f\n", d, f);//0.333333 0.333333
printf("%.12lf %.12f\n", d, f);//0.333333333333 0.333333343267
printf("%.16lf %.16f\n", d, f);//0.3333333333333333 0.3333333432674408
}
8.编写一个程序,提示用户输入旅行的里程和消耗的汽油量。然后计算并显示消耗每加仑汽油行驶的英里数,显示小数点后面一位数字。接下来,使用1加仑大约3.785升,1英里大约为1.609千米,把单位是英里/加仑的值转换为升/100公里(欧洲通用的燃料消耗表示法),并显示结果,显示小数点后面 1 位数字。注意,美国采用的方案测量消耗单位燃料的行程(值越大越好),而欧洲则采用单位距离消耗的燃料测量方案(值越低越好)。使用#define 创建符号常量或使用 const 限定符创建变量来表示两个转换系数。
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
const double jl = 3.785;
const double yl = 1.609 * 100;
double lc, qyl;
printf("input lc and qyl:");
scanf("%lf %lf", &lc, &qyl);
printf("%lf\n", (qyl * jl) / (lc * yl));
}