当前位置: 首页 > news >正文

C语言的数组与字符串练习题1

C语言的数组与字符串练习题1

1. 数组初始化与遍历

题目描述:
编写一个C程序,初始化一个整数数组,包含10个元素,然后遍历并打印数组中的所有元素。

解题思路:
要初始化一个数组,可以在声明时直接给出初始值。遍历数组可以使用for循环,通过索引访问每个元素并打印。

程序流程如下:

  1. 声明并初始化一个包含10个整数的数组。
  2. 使用for循环遍历数组,从索引0到9。
  3. 在循环中打印每个数组元素。

详细代码:

#include <stdio.h>int main() {// 声明并初始化一个包含10个整数的数组int arr[10] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};// 使用for循环遍历数组printf("数组中的元素为:\n");for(int i = 0; i < 10; i++) {printf("arr[%d] = %d\n", i, arr[i]);}return 0;
}

代码注释:

  • int arr[10] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};:声明并初始化一个包含10个整数的数组。
  • for(int i = 0; i < 10; i++):使用for循环从索引0到9遍历数组。
  • printf("arr[%d] = %d\n", i, arr[i]);:打印当前索引和对应的数组元素。

2. 查找数组中的最大值和最小值

题目描述:
编写一个C程序,输入10个整数存储在数组中,找到并输出数组中的最大值和最小值。

解题思路:
要找到数组中的最大值和最小值,可以先假设第一个元素为最大值和最小值,然后遍历数组,比较每个元素与当前的最大值和最小值,进行更新。

程序流程如下:

  1. 声明一个数组,大小为10。
  2. 提示用户输入10个整数,并存储在数组中。
  3. 初始化maxmin为数组的第一个元素。
  4. 使用for循环遍历数组,从第二个元素开始比较。
  5. 根据比较结果更新maxmin
  6. 输出最大值和最小值。

详细代码:

#include <stdio.h>int main() {int arr[10];int max, min;// 提示用户输入10个整数printf("请输入10个整数:\n");for(int i = 0; i < 10; i++) {scanf("%d", &arr[i]);}// 初始化max和min为第一个元素max = arr[0];min = arr[0];// 遍历数组,查找最大值和最小值for(int i = 1; i < 10; i++) {if(arr[i] > max) {max = arr[i];}if(arr[i] < min) {min = arr[i];}}// 输出结果printf("数组中的最大值是 %d。\n", max);printf("数组中的最小值是 %d。\n", min);return 0;
}

代码注释:

  • int arr[10];:声明一个大小为10的整数数组。
  • for(int i = 0; i < 10; i++):循环读取用户输入的10个整数并存储在数组中。
  • max = arr[0]; min = arr[0];:初始化最大值和最小值为数组的第一个元素。
  • if(arr[i] > max):如果当前元素大于max,更新max
  • if(arr[i] < min):如果当前元素小于min,更新min
  • printf:输出数组中的最大值和最小值。

3. 数组元素求和与平均值

题目描述:
编写一个C程序,输入5个浮点数存储在数组中,计算并输出数组元素的总和和平均值。

解题思路:
要计算数组元素的总和,可以使用for循环将所有元素累加起来。平均值则是总和除以元素的数量。

程序流程如下:

  1. 声明一个数组,大小为5,类型为float
  2. 提示用户输入5个浮点数,并存储在数组中。
  3. 使用for循环遍历数组,累加所有元素的值。
  4. 计算平均值。
  5. 输出总和和平均值。

详细代码:

#include <stdio.h>int main() {float arr[5];float sum = 0.0, average;// 提示用户输入5个浮点数printf("请输入5个浮点数:\n");for(int i = 0; i < 5; i++) {scanf("%f", &arr[i]);}// 计算总和for(int i = 0; i < 5; i++) {sum += arr[i];}// 计算平均值average = sum / 5;// 输出结果printf("数组元素的总和是 %.2f。\n", sum);printf("数组元素的平均值是 %.2f。\n", average);return 0;
}

代码注释:

  • float arr[5];:声明一个大小为5的浮点数数组。
  • float sum = 0.0, average;:声明并初始化总和变量为0,平均值变量。
  • for(int i = 0; i < 5; i++):循环读取用户输入的5个浮点数并存储在数组中。
  • sum += arr[i];:将当前数组元素累加到sum中。
  • average = sum / 5;:计算平均值。
  • printf:输出总和和平均值。

4. 反转数组

题目描述:
编写一个C程序,输入10个整数存储在数组中,然后将数组中的元素反转,并输出反转后的数组。

解题思路:
要反转数组,可以使用两个指针(或索引)从数组的两端开始,交换对应位置的元素,直到中间位置。

程序流程如下:

  1. 声明一个数组,大小为10。
  2. 提示用户输入10个整数,并存储在数组中。
  3. 使用for循环,从数组的开始和结束,交换对应的元素。
  4. 输出反转后的数组。

详细代码:

#include <stdio.h>int main() {int arr[10];int temp;// 提示用户输入10个整数printf("请输入10个整数:\n");for(int i = 0; i < 10; i++) {scanf("%d", &arr[i]);}// 反转数组for(int i = 0; i < 10 / 2; i++) {temp = arr[i];arr[i] = arr[10 - 1 - i];arr[10 - 1 - i] = temp;}// 输出反转后的数组printf("反转后的数组元素为:\n");for(int i = 0; i < 10; i++) {printf("arr[%d] = %d\n", i, arr[i]);}return 0;
}

代码注释:

  • int arr[10];:声明一个大小为10的整数数组。
  • for(int i = 0; i < 10; i++):循环读取用户输入的10个整数并存储在数组中。
  • for(int i = 0; i < 10 / 2; i++):循环遍历数组的一半,交换元素。
  • temp = arr[i]; arr[i] = arr[10 - 1 - i]; arr[10 - 1 - i] = temp;:交换数组中对应位置的元素。
  • for(int i = 0; i < 10; i++):循环输出反转后的数组元素。

5. 数组排序(升序)

题目描述:
编写一个C程序,输入5个整数存储在数组中,对数组进行升序排序,并输出排序后的数组。

解题思路:
可以使用简单的排序算法,如冒泡排序。通过多次遍历数组,比较相邻元素并交换位置,使得最大的元素逐渐移动到数组的末尾。

程序流程如下:

  1. 声明一个数组,大小为5。
  2. 提示用户输入5个整数,并存储在数组中。
  3. 使用嵌套for循环实现冒泡排序。
  4. 输出排序后的数组。

详细代码:

#include <stdio.h>int main() {int arr[5];int temp;// 提示用户输入5个整数printf("请输入5个整数:\n");for(int i = 0; i < 5; i++) {scanf("%d", &arr[i]);}// 冒泡排序(升序)for(int i = 0; i < 5 - 1; i++) {for(int j = 0; j < 5 - 1 - i; j++) {if(arr[j] > arr[j + 1]) {// 交换arr[j]和arr[j + 1]temp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = temp;}}}// 输出排序后的数组printf("升序排序后的数组元素为:\n");for(int i = 0; i < 5; i++) {printf("arr[%d] = %d\n", i, arr[i]);}return 0;
}

代码注释:

  • int arr[5];:声明一个大小为5的整数数组。
  • for(int i = 0; i < 5; i++):循环读取用户输入的5个整数并存储在数组中。
  • 冒泡排序部分:
    • 外层循环控制排序的次数,每次将最大的元素移动到未排序部分的末尾。
    • 内层循环比较并交换相邻的元素。
  • printf:输出升序排序后的数组元素。

http://www.lryc.cn/news/612555.html

相关文章:

  • VINS-Fusion+UWB辅助算法高精度实现
  • KNN算法:从原理到实战应用
  • 人工智能——深度学习——认识Tensor
  • k8s的存储之statefulset控制器
  • 数据结构(4)
  • 图解 Claude Code 子智能体 Sub-agent
  • Verilog 仿真问题:打拍失败
  • C语言高级编程技巧与最佳实践
  • 如何给小语种视频生成字幕?我的实测方法分享
  • docker-compose部署file browser
  • P1983 [NOIP 2013 普及组] 车站分级
  • Spring文件泄露与修复方案总结
  • Unity 调节 Rigidbody2D 响应速度的解决方案【资料】
  • 聚合链接网站源码部署教程
  • 【开源分享】can-utils:深入解析 Linux CAN 工具集
  • 面试经典150道之多数元素
  • nflsoi 8.6 题解
  • Python day36
  • stm32项目(22)——基于stm32的智能病房监护系统
  • 基于PHP的论坛社交网站系统开发与设计
  • Git Cherry-Pick 指南
  • 中国移动h10g-01_S905L处理器安卓7.1当贝纯净版线刷机包带root权限_融合终端网关
  • HTTP Flood攻击:数字时代的“蝗虫灾害“与智能防护之道
  • Python赋能气象与气候数据分析的生态构建与实战路径
  • 使用R将nc文件转换为asc文件或者tif文件
  • PyTorch入门引导
  • C++、STL面试题总结(一)
  • 【C++】二叉树进阶
  • JavaWeb(04)
  • Perforce P4 Plan - DevOps实时规划工具