C语言程序设计实验与习题指导 (第4版 )课后题-第二章+第三章

C语言程序设计实验与习题指导课后题-第二章

二--1-9.【赋值的语句】--p141


2-3【在循环结束后,k 的值为最后一次计算的结果,即 5 + 5 = 10】

二--2-4【x / y 是整数除法,结果为 0 (因为 1 / 2 在整数除法中结果为 0)】--p141

c 复制代码
#include<stdio.h>
int main(){
	int x=1,y=2;

	printf("%d",1.0+x/y);
}

x / y 是整数除法,结果为 0 (因为 1 / 2 在整数除法中结果为 0)。

1.0 + 0 是浮点数加上整数,结果为 1.0。

printf 函数将浮点数 1.0 转换为整数 1,并打印出来。

二--2-5【计算1 + 12 + 123 + 1234 + 12345 = 13715】----p141

c 复制代码
int sum = 0;  // 用于累加总和
int t= 0;  // 用于构建当前数字
int digit = 1;  // 从1开始构建
int maxDigits = 5;  // 最大位数
循环构建每个数字:


for (int i = 1; i <= maxDigits; i++) {
    t= t* 10 + digit;  // 构建当前数字
    sum += t;  // 累加当前数字
}
t从0开始,每次循环乘以10并加上当前的 digit。
sum 用于累加每个构建的数字。
输出
这段代码的输出将是:

1 + 12 + 123 + 1234 + 12345 = 13715
逐步构建过程
第一次迭代(i = 1): t= 0 * 10 + 1 = 1  sum = 0 + 1 = 1
第二次迭代(i = 2): t= 1 * 10 + 2 = 12  sum = 1 + 12 = 13
第三次迭代(i = 3): t= 12 * 10 + 3 = 123  sum = 13 + 123 = 136
第四次迭代(i = 4): t= 123 * 10 + 4 = 1234  sum = 136 + 1234 = 1370
第五次迭代(i = 5): t= 1234 * 10 + 5 = 12345  sum = 1370 + 12345 = 13715
完整代码

最终输出将是:

1 + 12 + 123 + 1234 + 12345 = 13715

三--2-8【if语句只对最近的一句管用】

c 复制代码
#include <stdio.h>

int main() {
    int a = 3, b = 4, c = 5, t = 99;

    if (b < a && a < c) t = a;a = c;c = t;
    if (a < c && b < c) t = b;b = a;a = t;

    printf("%d%d%d\n", a, b, c);

    return 0;
}

第一个条件判断:if (b < a && a < c) t = a;

b < a 是 4 < 3,结果为 0(假)。因此,整个条件 b < a && a < c 为假。

t 的值仍为 99。

重新赋值:a = c;c = t;a 的值变为 5。c 的值变为 99。

第二个条件判断:if (a < c && b < c) t = b;

a < c 是 5 < 99,结果为 1(真)。b < c 是 4 < 99,结果为 1(真)。

因此,整个条件 a < c && b < c 为真。t 的值变为 b 的值,即 4。

重新赋值:b = a;a = t;b 的值变为 5。a 的值变为 4。

最终变量值

a = 4

b = 5

c = 99

t = 4 (但 t 不影响最终输出)

三--2-9if(a>b>c) 【要小心】--p147

c 复制代码
#include<stdio.h>
int main(){
	int a=5,b=4,c=3,d=2;
	if(a>b>c)
		printf("%d\n",d);
	else if((c-1>=d)==1)
		printf("%d",d+1);
	else
		printf("%d",d+2);
		return 0;
}是怎么运行的

第一个条件:a > b > c 被解析为 (a > b) > c。
5 > 4 结果为 1(真)。 1 > 3 结果为 0(假)。  因此,第一个条件为假。

第二个条件:c - 1 >= d 被解析为 2 >= 2。
结果为 1(真)。  (c - 1 >= d) == 1 结果为 1(真)。  因此,执行第二个条件的分支。

输出:输出 d + 1 即 3。
相关推荐
oioihoii4 分钟前
现代C++:一场静默的革命,告别“C with Classes”
c语言·jvm·c++
q***979113 分钟前
Spring Cloud GateWay搭建
java
明洞日记29 分钟前
【设计模式手册007】原型模式 - 通过复制创建对象的艺术
java·设计模式·原型模式
Jonathan Star32 分钟前
JavaScript 中,原型链的**最顶端(终极原型)只有一个——`Object.prototype`
开发语言·javascript·原型模式
普通网友38 分钟前
C++中的组合模式
开发语言·c++·算法
q***615038 分钟前
PHP进阶-在Ubuntu上搭建LAMP环境教程
开发语言·ubuntu·php
Dneccc40 分钟前
Qt5配置MSVC2017
开发语言·qt
江公望42 分钟前
Qt QByteArray类型,10分钟讲清楚
开发语言·c++·qt
小灰灰搞电子42 分钟前
Qt Sensors 传感器框架详解
开发语言·qt
LNN20221 小时前
Qt 5.8 中的 Qt Test:轻松实现自动化测试
开发语言·qt