题目1:判断整数的符号性质(流程控制)
题目描述:
编写一个程序,提示用户输入一个整数,然后判断该整数是正数、负数还是零,并输出相应的提示信息。
输入示例:
5
输出示例:
正数
✅参考答案:
#include <stdio.h>
int main() {
int num;
printf("请输入一个整数:");
scanf("%d", &num);
if (num > 0)
printf("正数\n");
else if (num < 0)
printf("负数\n");
else
printf("零\n");
return 0;
}
题目2:输出满足特定条件的整数(选择+循环)
题目描述:
请编写程序,输出1到100之间所有满足以下条件的整数:能够被7整除,但不能被5整除。每个数字之间用空格隔开。
输出示例:
7 14 21 28 42 49 56 63 77 84 91 98
✅参考答案:
#include <stdio.h>
int main() {
for (int i = 1; i <= 100; i++) {
if (i % 7 == 0 && i % 5 != 0) {
printf("%d ", i);
}
}
printf("\n");
return 0;
}
题目3:查找数组中的最大值及其下标
题目描述:
输入10个整数,存入数组中。程序需要遍历数组,找出其中的最大值及其在数组中的下标(下标从0开始),并输出。
输入示例:
5 7 2 9 4 3 8 0 1 6
输出示例:
最大值是9,下标是3
✅参考答案:
#include <stdio.h>
int main() {
int arr[10], max, index = 0;
printf("请输入10个整数:");
for (int i = 0; i < 10; i++) {
scanf("%d", &arr[i]);
}
max = arr[0];
for (int i = 1; i < 10; i++) {
if (arr[i] > max) {
max = arr[i];
index = i;
}
}
printf("最大值是%d,下标是%d\n", max, index);
return 0;
}
题目4:统计字符串中的数字字符个数
题目描述:
编写一个程序,读取一个字符串(不包含空格),统计其中**数字字符(0-9)**出现的个数,并输出结果。
输入示例:
abc123xy7z
输出示例:
数字个数是4
✅参考答案:
#include <stdio.h>
int main() {
char str[100];
int count = 0;
printf("请输入一个字符串:");
scanf("%s", str);
for (int i = 0; str[i] != '\0'; i++) {
if (str[i] >= '0' && str[i] <= '9') {
count++;
}
}
printf("数字个数是%d\n", count);
return 0;
}
题目5:自定义函数求最大公约数
题目描述:
定义一个名为 gcd
的函数,接收两个正整数作为参数,返回它们的最大公约数。在主函数中接收用户输入两个正整数,调用该函数并输出结果。
输入示例:
12 18
输出示例:
最大公约数是:6
✅参考答案:
#include <stdio.h>
int gcd(int a, int b) {
while (b != 0) {
int temp = b;
b = a % b;
a = temp;
}
return a;
}
int main() {
int a, b;
printf("请输入两个正整数:");
scanf("%d %d", &a, &b);
printf("最大公约数是:%d\n", gcd(a, b));
return 0;
}
题目6:使用指针交换两个变量的值
题目描述:
定义一个函数 swap(int *a, int *b)
,使用指针参数交换两个整数变量的值。在主函数中测试该函数。
输出示例:
交换前:a = 3, b = 8
交换后:a = 8, b = 3
✅参考答案:
#include <stdio.h>
void swap(int *a, int *b) {
int temp = *a;
*a = *b;
*b = temp;
}
int main() {
int a = 3, b = 8;
printf("交换前:a = %d, b = %d\n", a, b);
swap(&a, &b);
printf("交换后:a = %d, b = %d\n", a, b);
return 0;
}
题目7:使用指针实现字符串反转
题目描述:
编写一个函数 void reverse(char *str)
,使用指针操作将字符串反转(不使用标准库函数strrev)。在主函数中输入字符串并调用该函数,输出反转结果。
输入示例:
hello
输出示例:
olleh
✅参考答案:
#include <stdio.h>
#include <string.h>
void reverse(char *str) {
char *p1 = str;
char *p2 = str + strlen(str) - 1;
while (p1 < p2) {
char temp = *p1;
*p1 = *p2;
*p2 = temp;
p1++;
p2--;
}
}
int main() {
char str[100];
printf("请输入字符串:");
scanf("%s", str);
reverse(str);
printf("反转后:%s\n", str);
return 0;
}
题目8:结构体数组查找最高成绩
题目描述:
定义一个结构体 Student
,包含学号(整型)、姓名(字符串)和成绩(浮点型)。从用户输入中读取5名学生的信息,找出成绩最高的学生并输出其完整信息。
输入示例:
101 张三 88.5 102 李四 92.0 103 王五 76.5 104 赵六 95.0 105 孙七 90.5
输出示例:
最高分学生:学号104,姓名:赵六,成绩:95.00
✅参考答案:
#include <stdio.h>
struct Student {
int id;
char name[20];
float score;
};
int main() {
struct Student s[5];
printf("请输入5个学生的信息(学号 姓名 成绩):\n");
for (int i = 0; i < 5; i++) {
scanf("%d %s %f", &s[i].id, s[i].name, &s[i].score);
}
int maxIndex = 0;
for (int i = 1; i < 5; i++) {
if (s[i].score > s[maxIndex].score) {
maxIndex = i;
}
}
printf("最高分学生:学号%d,姓名:%s,成绩:%.2f\n",
s[maxIndex].id, s[maxIndex].name, s[maxIndex].score);
return 0;
}
题目9:文件写入与读取操作
题目描述:
从键盘读取若干行字符串,将其写入文本文件中。然后从该文件中读取内容并在控制台显示。
-
文件名:
test.txt
-
行数由用户输入确定。
✅参考答案:
#include <stdio.h>
int main() {
FILE *fp;
char str[100];
int n;
fp = fopen("test.txt", "w");
if (!fp) {
printf("文件打开失败\n");
return 1;
}
printf("请输入要写入的行数:");
scanf("%d", &n);
getchar(); // 清除回车
printf("请输入内容:\n");
for (int i = 0; i < n; i++) {
fgets(str, sizeof(str), stdin);
fputs(str, fp);
}
fclose(fp);
fp = fopen("test.txt", "r");
if (!fp) {
printf("文件读取失败\n");
return 1;
}
printf("从文件读取内容:\n");
while (fgets(str, sizeof(str), fp)) {
printf("%s", str);
}
fclose(fp);
return 0;
}
题目10:数组排序(冒泡法)
题目描述:
从用户处输入一个长度为n的整型数组(n不超过100),使用冒泡排序算法对其按从小到大顺序排序,并输出排序后的数组。
输入示例:
5(表示5个数字)
9 2 5 1 3
输出示例:
1 2 3 5 9
✅参考答案:
#include <stdio.h>
int main() {
int arr[100], n;
printf("请输入数组元素个数:");
scanf("%d", &n);
printf("请输入%d个整数:", n);
for (int i = 0; i < n; i++)
scanf("%d", &arr[i]);
// 冒泡排序
for (int i = 0; i < n - 1; i++) {
for (int j = 0; j < n - 1 - i; j++) {
if (arr[j] > arr[j + 1]) {
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
printf("排序结果:");
for (int i = 0; i < n; i++)
printf("%d ", arr[i]);
printf("\n");
return 0;
}
本文系统整理了适用于C语言课程期末复习的10道编程题目,覆盖了基本语法、流程控制、数组与字符串、函数与指针、结构体、文件操作以及常用算法(如排序)等核心知识点。每一道题目均配有详细的题目描述、示例输入输出,并提供了完整、规范的C语言参考代码,方便读者理解与动手练习。
本练习题适用于以下场景:
-
期末考试复习
-
编程基础训练
-
面试前强化练习
-
C语言教学练习题参考
无论你是C语言初学者,还是想查漏补缺的同学,本文都将为你提供一份实用且系统的编程题参考资料