大学教材《C语言程序设计》(浙大版)课后习题解析 | 第一、二章

news2024/12/27 1:16:09

概述

      本文主要提供《C语言程序设计》(浙大版) 第一、二章课后习题解析,以方便同学们完成题目后作为参考对照。后续将写出三、四章节课后习题解析,如想了解更多,请持续关注该专栏。

专栏直达链接:《C语言程序设计》(浙大版)_孟俊宇-MJY的博客-CSDN博客icon-default.png?t=N7T8http://t.csdnimg.cn/ZtcgY

一.第一章

[1-1]

对C语言来说,下列标示符中哪些是合法的,哪些是不合法的?

      total,_debug, Large&Tall, Counter1, begin_

解析:

合法的: total、_debug、 Counter1、 begin_ 
不合法的: Large&Tall

[1-2]

改写 1.4 节中的流程图 1.2, 求 1-100 中能被 6 整除的所有整数的和。

解析:

[1-3]

改写 1.4 节中的程序,求 1-100 中能被 6 整除的所有整数的和,并在编程环境中验证该程序的运行结果。

解析: 

#include <stdio.h>
int main(void)
{
	int i,
		sum = 0;
	for (i = 1; i <= 100; i++)
		if (i % 6 == 0)
			sum = sum + i;
	printf("sum=%d\n", sum);
	return 0;
}

输出结果:

sum = 816

[1-4]

对于给定的整数 n (n>1),请设计一个流程图判别 n 是否为一个素数(只能被1和自己整除的整数),并分析该流程图中哪些是顺序结构、哪些是分支结构和循环结构。

解析:

二.第二章 

1.选择题

[2-1]

改正下列程序中( )处错误后,程序的运行结果是在屏幕上显示短句“ Welcome to You!"。

#include <stdio.h>
int main(void)
{
	printf(Welcome to You! \n")
	return 0;
}

   A.1            B.2            C.3            D.4                                     

解析:B

printf() 函数是系统提供的库函数,在系统文件stdio.h中声明。

printf() 函数的格式为:

printf(格式控制字符串,输出参数1,...,输出参数n);

所以,printf里的字符串要加双引号。

printf语句末尾要以分号结束。

[2-2]

C语言表达式( )的值不等于1。

A. 123 / 100

B. 901%10

C.76%3

D.625%5

解析:D 

选项A:123/100 的结果是 1 。123 除以 100,商 1 余 23 ,这里取商。

选项B:901%10 的结果是 1 。901除以10,商 90 余 1 ,这里取余数。

选项C:76%3 的结果是 1 。76 除以 3 ,商 25 余 1,这里取余数。

选项D:625%5 的结果是 0 。625 除以 5 ,商 125 余 0 ,这里取余数。

[2-3]

假设 i 和 j 是整型变量,以下语句( )的功能是在屏幕上显示形如 `i*j=i*` j的一句乘法口诀。例如,当 i=2 ,j=3 时,显示 2\*3=6。

A. printf("d * %d=%d\n", i, j, i*j);

B. printf("%d * %d=%d\n",i, j, i*j);

C. printf( "%d * %d=%d\n",i, j);

D. printf("%d=%d * %d\n", i, j, i*j);

解析:B

选项A:printf() 函数中,表示整数,对应 %d 。

选项B:正确

选项C:printf() 函数中,3 个 %d ,需要对应 3 个int类型数值。

选项D:printf() 函数中,3 个 %d,要和后面的参数一一对应。

[2-4]

若 x 是 double 型变量,n 是 int 型变量,执行以下语句( ),并输入3 1.25 后,x=1.25,n=3。

A. scanf( "%d%lf",&n, &x) ;

B. scanf( "%lf%d",&x,&n);

C. scanf( "%lf%d", &n, &x);

D. scanf( "%d, %lf", &n, &x);

解析:A

题目里说输入 3 和 1.25 。所以要先输入 n 的值,再输入 x 的值。x 是 double 类型,所以对应 %lf ,n 是 int 类型,所以对应 %d 。所以最后选 A。

[2-5]

下列运算符中,优先级最低的是( )。

A. *

B. =

C. ==

D. %

解析:B

选项A * 是算术运算符,选项B=是赋值运算符,选项C==是关系运算符,选项D%是算术运算符。

这里的优先级:算术运算符 > 关系运算符 > 赋值运算符

所以选项B = 的优先级最低。

[2-6]

将以下 if-else 语句补充完整,正确的选项是( )。

if(x>=y){
	printf( "max=%d\n", x);
______________
	printf( "max=%d\n",y);
}

A. else;

B. else {

C.}else{

D. else

解析:C

{}要成对儿使用。

[2-7]

为了检查第 6 题的 if-else 语句的两个分支是否正确,至少需要设计 3 组测试用例,其相应的输入数据和预期输出结果是( )。

A.输入 3 和 4 ,输出 4 ; 输入 5 和 100 , 输出 100 ; 输入 4 和 3 ,输出 4 。

B.输入 3 和 4 ,输出 4 ; 输入 100 和 5 ,输出 100; 输入 4 和 3 ,输出 4 。

C.输入 3 和 4 ,输出 4 ; 输入 5 和 5 ,输出 5 ; 输入 -2 和 -1 ,输出 -1 。

D.输入 3 和 4 ,输出 4 ; 输入 5 和 5 ,输出 5 ; 输入 4 和 3 ,输出 4 。

解析:D

题目中是要比较 2 个数的大小,分为 3 种情况, a > b,a = b,a < b。所以选项 D 正确。

[2-8]

对 C 语言程序,以下说法正确的是( )。

A.main 函数是主函数,一定要写在最前面。

B.所有的自定义函数,都必须先声明。

C.程序总是从 main 函数开始执行的。

D.程序中只能调用库函数,不能自己定义函数。

解析:C

程序总是从 main() 函数开始。

2.填空题

[2-1]

假设 k 是整型变量,计算表达式 1/k , 结果的数据类型是( ),计算表达式 1.0/k,结果的数据类型是( )。

解析:整型,实型

整型除整型的结果也是整型。1.0是实型(浮点型),除整型,要先将除法运算符两侧的数据类型统一,所以系统会自动进行类型转换。将k由整型转为浮点型,再进行计算。

[2-2]

输入 3 和 2 ,下列程序段的输出结果是( )。

int a, b;
scanf("%d%d",&a, &b);
a=a+b;
b=a-b;
a=a-b;
printf("a=%d#b=%d\n",a, b);

解析: a=2#b=3。

整个程序其实是在进行 a 和 b 的数值交换。通过输入赋值,这里 a 初始值为 3 , b 初始值为 2 。执行a=a+b 计算之后,a 的值为 5 ,b 的值依然为 2 。然后执行 b=a-b 计算之后,a 的值依然为 5 ,但是 b 的值被更改为 3 ,然后再执行 a=a-b 计算之后,a 的值被改为 2 ,b 的值依然为 3 。至此,交换了 a 和 b 的数值。

[2-3]

交换变量的值。输入 a 和 b ,然后交换它们的值,并输出交换后 a 和 b 的值。请填空。

int a, b, temp;
printf( "Enter a, b:");
scanf("%d%d", &a, &b);
______________
a=b;
______________
printf( "a=%d#b=%d\n", a, b);

解析: 

temp=a;
b=temp;

上面的代码已经定义了第三个变量 temp,用于交换 a 和 b 的值。我们先将 a 的值赋值给 temp,然后 a=b 表示将b 的值赋值给 a ,最后再将 temp 中存储的a的值,赋值给 b 。就完成了交换 a 和 b 的值。 

[2-4]

假设 n 是整型变量,判断 n 是偶数的表达式是( )。

解析:n%2==0

所谓的偶数,就是能被 2 整除的数,那么我们让 n 除 2 然后取它的余数,判断是否为 0 即可。

[2-5]

与数学式<省略>对应的 C 语言表达式是( )。

解析:

sqrt(s*(s-a)*(s-b)*(s-c))

在 c 语言中有函数库 math.h,里面有函数 sqrt() 用于表示开平方。 

[2-6]

调用数学库函数时,编译预处理命令为( )。调用输入输出库函数时,编译预处理命令为( )。

解析: 

#include<math.h> 
#include<stdio.h>

编译预处理命令使用#include,后面跟着函数库。数学函数库需要math.h,输入输出函数是在系统文件stdio.h中声明。注意:编译预处理命令的末尾不加分号。

[2-7]

本章介绍了 3 种运算符,分别是算术、赋值和关系运算符,按照优先级从高到低的顺序排列为( )运算符、( )运算符、( )运算符。

解析:算术,关系,赋值。

算术运算符的优先级高于关系运算符,关系运算符的优先级高于赋值运算符。

[2-8]

下列程序段的输出结果是( )。

int k , flag;
if(k=0){
	flag=0;
}else{
	flag=1;
}
printf( "k=%d#flag=%d\n",k,flag);

解析: k=0#flag=1

这里首先声明了两个 int 类型的变量 k 和 flag ,然后执行 if 语句,判断条件为 k=0 ,这里是个赋值语句,这里 k 被赋值为 0 ,但是作为 if 语句的条件是不成立的,会执行 else 语句,flag 被赋值为 1 。所以最终结果就是 k 为 0 ,flag 为 1。

[2-9]

C 语言 3 种基本的控制结构是( )结构、( )结构和( )结构。

解析:顺序,分支,循环。

[2-10]

下列程序段的输出结果是( )。

int i;
	double s = 0;
	for (i = 1; i < 4; i++)
	{
		s = s + 1.0 / i;
		printf("i=%d#s=%.3f\n", i, s);
	}
	printf("i=%d#s=%.3f\n",i, s);

解析: 

i=1#s=1.000
i=2#s=1.500
i=3#s=1.833
i=4#s=1.833

for 循环里,

i 的初始值为 1 ,s 的初始值为 0+1.0/1,结果为 1.0 ,第一次打印的时候保留小数点后 3 位,结果为 i=1#s=1.000。

然后累加 i 的值为 2 ,s的 值为1.0+1.0/2,等于1.0+0.5等于1.5,所以第二次打印的时候保留小数点后3位,结果为i=2#s=1.500。

然后再累加i的值为3,s的值为1.5+1.0/3,等于1.5+0.333等于1.833,所以第三次打印的死后保留小数点后3位,结果为i=3#s=1.833。

然后再累加i的值为4,不满足for循环的条件,循环结束了。

继续执行,打印最后一次:i=4#s=1.833。

3.程序设计题

[2-1]

求整数均值:输入 4 个整数,计算并输出这些整数的和与平均值,其中平均值精确到小数点后1位。试编写相应程序。

解析:

#include <stdio.h>
int main(void)
{
	//求整数均值:输入 4 个整数,计算并输出这些整数的和与平均值,其中平均值精确到小数点后1位。试编写相应程序。
	int a, b, c, d, sum = 0;
	double average;
	printf("input a,b,c,d:");
	scanf("%d%d%d%d", &a, &b, &c, &d);
	sum = a + b + c + d;
	average = sum / 4.0;
	printf("average=%.1lf\n", average);
	return 0;
}

输出结果:

input a,b,c,d:8 4 19 33
average=16.0

[2-2]

阶梯电价:为了提倡居民节约用电,某省电力公司执行“阶梯电价”,安装一户一表的居民用户电价分为两个“阶梯”:月用电量 50kW . h ( 含 50kW. h )以内的,电价为 0.53 元 /kW . h;超过 50kW . h 的,超出部分的用电量电价每千瓦时上调 0.05 元。输入用户的月用电量(千瓦时),计算并输出该用户应支付的电费(元),若用电量小于 0 ,则输出" Invalid Value!"。试编写相应程序。

解析:

#include <stdio.h>
int main(void)
{
	/*
	阶梯电价:为了提倡居民节约用电,某省电力公司执行“阶梯电价”,安装一户一表的居民用户电价分为两个“阶梯”:
	月用电量 50kW . h ( 含 50kW,h )以内的,电价为 0.53 元 /kW . h;
	超过 50kW . h 的,超出部分的用电量电价每千瓦时上调 0.05 元。
	输入用户的月用电量(千瓦时),计算并输出该用户应支付的电费(元),
	若用电量小于 0 ,则输出" Invalid Value!"。试编写相应程序。
	*/
	double x, y; // x为用户月用电量,单位为千瓦每时。y为电费,单位 元。
	printf("input x:");
	scanf("%lf", &x);
	if (x < 0)
	{
		printf("Invaild Value!\n");
	}
	else if (x <= 50)
	{
		y = 0.53 * x;
		printf("电费 = %lf 元\n", y);
	}
	else if (x > 50)
	{
		y = 0.53 * 50 + (x - 50) * (0.53 + 0.05);
		printf("电费 = %lf 元\n", y);
	}
	return 0;
}

输出结果:

input x:44.6
电费 = 23.638000

[2-3]

序列求和:输入两个正整数 m 和 n ( 0<m≤n),求<省略> ,结果保留 6 位小数。试编写相应程序。

解析:

#include <stdio.h>
int main(void)
{
	/*
	序列求和:输入两个正整数 m 和 n ( 0<m≤n),求 $ \sum_{i=m}^n(i^2+\frac{1}{i}) $  ,结果保留 6 位小数。试编写相应程序。
	*/
	int m, n, i;
	double sum = 0;
	printf("input m,n(0<m<=n):");
	scanf("%d%d", &m, &n);
	for (i = m; i <= n; i++)
	{
		sum += i * i + 1.0 / i;
	}
	printf("∑=%lf\n", sum);
	return 0;
}

输出结果:

input m,n(0<m<=n):2 9
Σ=285.828968

[2-4]

求交错序列前 n 项和:输入一个正整数 n ,计算交错序列<省略>的前 n 项之和。试编写相应程序。

解析:

#include <stdio.h>
int main(void)
{
	/*
	求交错序列前n项和:输入一个正整数n,计算交错序列的前n项之和。试编写相应程序。
	*/
	int i, n, flag = 1;
	double sum = 0;
	printf("input n:");
	scanf("%d", &n);
	for (i = 1; i <= n; i++)
	{
		sum += (double)flag * i / (2 * i - 1);
		flag = -flag;
	}
	printf("sum = %lf\n", sum);
	return 0;
}

输出结果:

input n:18
sum = 0.385760

[2-5]

平方根求和:输入一个正整数 n ,计算<省略>的值(保留 2 位小数)。可包含头文件math.h ,并调用 sqrt( ) 函数求平方根。试编写相应程序。

解析:

#include <stdio.h>
#include <math.h>
int main(void)
{
	/*
	平方根求和:输入一个正整数 n ,计算 $ 1+\sqrt{2}+\sqrt{3}+...+\sqrt{n} $ 的值(保留 2 位小数)。可包含头文件math.h ,并调用 sqrt( ) 函数求平方根。
	*/
	int n, i;
	double sum = 0;
	printf("input n:");
	scanf("%d", &n);
	for (i = 1; i <= n; i++)
	{
		sum += sqrt(i);
	}
	printf("sum = %lf\n", sum);
	return 0;
}

输出结果:

input n:8
sum = 16.306001

[2-6]

求给定序列前 n 项和 ( 1!+2!+...):输入一个正整数 n,求 e=1!+2!+3!+...+n! 的值。要求定义和调用函数fact(n) 计算 n!,函数类型是double。试编写相应程序。

解析:

#include <stdio.h>
double fact(int n);
int main(void)
{
	/*
	求给定序列前 n 项和 ( 1!+2!+...):输入一个正整数 n,
	求 e=1!+2!+3!+...+n! 的值。要求定义和调用函数fact(n) 计算 n!,函数类型是double。
	*/
	int n, e = 0, i;
	printf("input n:");
	scanf("%d", &n);
	for (i = 1; i <= n; i++)
	{
		e += fact(i);
	}
	printf("e = %d\n", e);
	return 0;
}
double fact(int n)
{
	int i;
	double product = 1;
	for (i = 1; i <= n; i++)
	{
		product *= i;
	}
	return product;
}

输出结果:

input n:5
e = 153

总结

      以上为本篇文章的所有内容,后续将各个章节课后习题解析,如想了解更多,请持续关注该专栏。如有疑问或提供意见,请指出,谢谢!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1541184.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

《深入浅出LLM 》(二):大模型基石知识

&#x1f389;AI学习星球推荐&#xff1a; GoAI的学习社区 知识星球是一个致力于提供《机器学习 | 深度学习 | CV | NLP | 大模型 | 多模态 | AIGC 》各个最新AI方向综述、论文等成体系的学习资料&#xff0c;配有全面而有深度的专栏内容&#xff0c;包括不限于 前沿论文解读、…

抖音IP属地怎么更改

抖音是一个非常受欢迎的短视频平台&#xff0c;吸引了无数用户在上面分享自己的生活和才艺。然而&#xff0c;随着快手的火爆&#xff0c;一些用户开始担心自己的IP地址会被他人获取&#xff0c;引起个人隐私风险。那么&#xff0c;抖音用户又该如何更改到别的地方呢&#xff1…

ArcGIS添加天地图底图服务

目录 一、注册天地图官网、申请Key 二、ArcGis配置和使用 1、配置 2、使用 三、其他方法 一、注册天地图官网、申请Key 进入官网&#xff0c;并注册账号。 地址&#xff1a;国家地理信息公共服务平台 天地图 (tianditu.gov.cn) 点击地图API&#xff0c;申请Key。 注意&am…

python闭包详解(实例)

“闭包”这个词语相信大多数学过编程的同学并不陌生&#xff0c;但是有时候理解起来还是有一定难度。 先看定义&#xff1a;闭包是由函数和与其相关的引用环境组合而成的实体。比如参考资源中就有这样的的定义&#xff1a;在实现深约束时&#xff0c;需要创建一个能显式表示引…

线段树(算法思想+模板+例题)

基础思想 : 介绍 线段树可以用来维护区间信息(区间和 &#xff0c; 区间最值 &#xff0c; 区间GCD等) &#xff0c;可以在log n的时间内执行区间修改 和 区间查询 ; 1 . 叶子结点的特点是左右结点相等 &#xff0c; 存储元素本身; 2 . 非叶子结点存储的是区间内的统计值 &…

力扣|两数相加|链表

给你两个 非空 的链表&#xff0c;表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的&#xff0c;并且每个节点只能存储 一位 数字。 请你将两个数相加&#xff0c;并以相同形式返回一个表示和的链表。 你可以假设除了数字 0 之外&#xff0c;这两个数都不会以 0 …

用户多部门切换部门,MySQL根据多个部门id递归获取所有上级(祖级)、获取部门的全路径(全结构名称)

背景 之前做过的项目&#xff0c;都是一个用户就一个部门的&#xff0c;现在碰到个一个用户在多个部门的需求&#xff0c;而且需要可以切换不同部门查看不同数据。 就比如说一个大公司下面有多个子公司&#xff0c;每个子公司有好多部门、子部门等等&#xff0c;然后有部分用…

JDK下载配置

一、JDK的作用 Java开发环境&#xff1a;JDK提供了完整的Java开发环境&#xff0c;包含编译器&#xff08;javac&#xff09;、解释器&#xff08;java&#xff09;、打包工具&#xff08;jar&#xff09;、文档生成工具&#xff08;javadoc&#xff09;等一系列工具&#xff0…

人工智能(Educoder)-- 搜索技术 -- 盲目式搜索

第1关&#xff1a;盲目搜索之宽度优先搜索算法 任务描述 本关任务&#xff1a;给定迷宫地图以及在迷宫中的起始位置&#xff0c;利用宽度优先搜索算法求解走出迷宫的最短路径长度&#xff0c;走出迷宫意味着达到迷宫地图的边界&#xff08;所有位置下标0开始&#xff09;。 …

基于python+vue超市在线销售系统的设计与实现flask-django-php-nodejs

根据此问题&#xff0c;研发一套超市在线销售系统&#xff0c;既能够大大提高信息的检索、变更与维护的工作效率&#xff0c;也能够方便信息系统的管理运用&#xff0c;从而减少信息管理成本&#xff0c;提高效率。 该超市在线销售系统采用B/S架构、并采用python语言以及django…

鸿蒙一次开发,多端部署(十二)资源使用

在页面开发过程中&#xff0c;经常需要用到颜色、字体、间距、图片等资源&#xff0c;在不同的设备或配置中&#xff0c;这些资源的值可能不同。有两种方式处理&#xff1a; 应用资源&#xff1a;借助资源文件能力&#xff0c;开发者在应用中自定义资源&#xff0c;自行管理这些…

I/O多路复用:select/poll/epoll

最基本的 Socket 模型 要想客户端和服务器能在网络中通信&#xff0c;那必须得使用 Socket 编程&#xff0c;它是进程间通信里比较特别的方式&#xff0c;特别之处在于它是可以跨主机间通信。 Socket 的中文名叫作插口&#xff0c;咋一看还挺迷惑的。事实上&#xff0c;双方要…

两直线交点算法 C

求两直线交点算法 有中间交点 则CD在AB异侧 A B A C A B A D \nobreak AB \times AC \newline AB \times AD ABACABAD 异号 叉乘后相乘小于零 等于零的几种情况 A B C与AB共线 D与AB共线 求交点&#xff0c;可由面积比例用叉乘计算 C E C D S A B C S A B C D . \frac…

解决前端跨域问题

前端跨域问题 该问题是由于前端的服务路径或端口和后台的不一致所导致的 Springboot跨域设置 import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.web.cors.CorsConfiguration; …

「媒体邀约」选择媒体公关公司邀约媒体有哪些优势-51媒体网

传媒如春雨&#xff0c;润物细无声&#xff0c;大家好&#xff0c;我是51媒体网胡老师。 选择媒体公关公司邀约媒体具有以下优势&#xff1a; 丰富的媒体资源&#xff1a;媒体公关公司通常与各大主流媒体、行业媒体、网络媒体等有着长期合作关系&#xff0c;拥有丰富的媒体资源…

ChatGPT论文指南|揭秘8大ChatGPT提示词研究技巧提升写作效率【建议收藏】

点击下方▼▼▼▼链接直达AIPaperPass &#xff01; AIPaperPass - AI论文写作指导平台 公众号原文▼▼▼▼&#xff1a; ChatGPT论文指南|揭秘8大ChatGPT提示词研究技巧提升写作效率【建议收藏】 目录 1.写作方法 2.方法设计 3.研究结果 4.讨论写作 5.总结结论 6.书…

Install Docker

Docker Desktop 直接安装 Docker Desktop Docker Desktop includes the Docker daemon (dockerd), the Docker client (docker), Docker Compose, Docker Content Trust, Kubernetes, and Credential Helper. Linux下安装Docker CE 参考官方文档 参见阿里云的文档 # step 1…

ClickHouse--11--物化视图

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 1.物化视图什么是物化视图? 1.1 普通视图1.2 物化视图1.3 优缺点1.4 基本语法1.5 在生产环境中创建物化视图1.6 AggregatingMergeTree 表引擎3.1 概念3.2 Aggregat…

WorkPlus一站式IM即时通讯解决方案,提升企业沟通效率与协作能力

在企业内部沟通与协作中&#xff0c;高效的即时通讯是实现团队协作与工作效率的重要保障。而WorkPlus以其稳定可靠的性能和全面的功能&#xff0c;为企业提供一站式的IM即时通讯解决方案&#xff0c;助力企业提升沟通效率与协作能力。IM即时通讯在企业中的重要性不言而喻。作为…

【索引失效】MySQL索引失效场景

1、对索引使用左或者左右模糊匹配 当我们使用左或者左右模糊匹配的时候&#xff0c;也就是 like %xx 或者 like %xx% 这两种方式都会造成索引失效。 比如下面的 like 语句&#xff0c;查询 name 后缀为「林」的用户&#xff0c;执行计划中的 typeALL 就代表了全表扫描&#xff…