引言
翁凯的《C语言程序设计》是一本深受广大编程初学者喜爱的教材。本书通过丰富的实例和习题,帮助读者深入理解C语言的基础知识和编程技巧。本文将针对书中的一些课后习题进行详细解答,并揭秘答案背后的原理。
习题一:编写一个C程序,计算两个整数的和
习题描述
编写一个C程序,从键盘输入两个整数,计算并输出它们的和。
代码示例
#include <stdio.h>
int main() {
int num1, num2, sum;
printf("请输入第一个整数:");
scanf("%d", &num1);
printf("请输入第二个整数:");
scanf("%d", &num2);
sum = num1 + num2;
printf("两个整数的和为:%d\n", sum);
return 0;
}
解答解析
此程序首先包含了stdio.h头文件,以便使用printf和scanf函数。main函数中定义了三个整型变量num1、num2和sum。通过scanf函数从键盘读取两个整数,然后计算它们的和,并使用printf函数输出结果。
习题二:编写一个C程序,实现判断一个数是否为素数
习题描述
编写一个C程序,从键盘输入一个整数,判断该数是否为素数,并输出结果。
代码示例
#include <stdio.h>
#include <stdbool.h>
bool isPrime(int num) {
if (num <= 1) return false;
for (int i = 2; i * i <= num; i++) {
if (num % i == 0) return false;
}
return true;
}
int main() {
int num;
printf("请输入一个整数:");
scanf("%d", &num);
if (isPrime(num)) {
printf("%d 是素数。\n", num);
} else {
printf("%d 不是素数。\n", num);
}
return 0;
}
解答解析
此程序定义了一个名为isPrime的函数,用于判断一个数是否为素数。主函数main中读取用户输入的整数,并调用isPrime函数进行判断。如果是素数,则输出相应信息;如果不是,也输出相应信息。
习题三:编写一个C程序,实现冒泡排序算法
习题描述
编写一个C程序,实现冒泡排序算法,对一组整数进行排序。
代码示例
#include <stdio.h>
void bubbleSort(int arr[], int n) {
for (int i = 0; i < n - 1; i++) {
for (int j = 0; j < n - i - 1; j++) {
if (arr[j] > arr[j + 1]) {
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
int main() {
int arr[] = {64, 34, 25, 12, 22, 11, 90};
int n = sizeof(arr) / sizeof(arr[0]);
bubbleSort(arr, n);
printf("排序后的数组:\n");
for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
解答解析
此程序定义了一个名为bubbleSort的函数,用于实现冒泡排序算法。main函数中定义了一个整数数组arr,并计算其长度。调用bubbleSort函数对数组进行排序,然后遍历并打印排序后的数组。
结语
通过对翁凯《C语言程序设计》中部分课后习题的详细解答,我们不仅巩固了C语言的基础知识,还学会了如何运用这些知识解决实际问题。希望这些解答能够帮助你更好地理解和掌握C语言编程。
