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。
相关推荐
心情好的小球藻18 分钟前
Python应用进阶DAY9--类型注解Type Hinting
开发语言·python
ldj202023 分钟前
SpringBoot为什么使用new RuntimeException() 来获取调用栈?
java·spring boot·后端
超龄超能程序猿24 分钟前
Spring 应用中 Swagger 2.0 迁移 OpenAPI 3.0 详解:配置、注解与实践
java·spring boot·后端·spring·spring cloud
惜.己30 分钟前
使用python读取json数据,简单的处理成元组数组
开发语言·python·测试工具·json
风象南36 分钟前
SpringBoot配置属性热更新的轻量级实现
java·spring boot·后端
洛阳泰山37 分钟前
Spring Boot 整合 Nacos 实战教程:服务注册发现与配置中心详解
java·spring boot·后端·nacos
Y40900137 分钟前
C语言转Java语言,相同与相异之处
java·c语言·开发语言·笔记
YuTaoShao38 分钟前
【LeetCode 热题 100】994. 腐烂的橘子——BFS
java·linux·算法·leetcode·宽度优先
布朗克16838 分钟前
java常见的jvm内存分析工具
java·jvm·数据库
都叫我大帅哥2 小时前
深入浅出 Resilience4j:Java 微服务的“免疫系统”实战指南
java·spring cloud