C语言数组编程实例

 

目录

概念

数组的初始化

访问数组元素

注意事项

编程实例

1. 基础操作

2. 常见算法

实际应用

4. 高级技巧

5. 应用场景

总结


概念

在C语言中,数组是一种用于存储相同类型数据项的集合。数组中的每个元素都拥有相同的变量名和数据类型,并通过索引来区分不同的元素。数组为处理大量相同类型的数据提供了一种有效的方法,使得代码更加简洁和易于管理。

1.一维数组:最简单的数组形式,可以看作是线性表。声明格式:

type arrayName[arraySize];

其中type是数组中元素的数据类型,arrayName是数组的名字,arraySize定义了数组能容纳的元素个数。

2.多维数组:除了最常见的二维数组外,还可以有三维甚至更多维度的数组。二维数组常用来表示矩阵或表格。声明格式(以二维数组为例):

type arrayName[rowSize][columnSize];

数组的初始化

数组可以在声明时进行初始化,对于一维数组:

int numbers[] = {1, 2, 3, 4, 5};

对于二维数组:

int matrix[2][3] = {{1, 2, 3}, {4, 5, 6}};

如果没有明确指定数组大小,编译器会根据提供的初始化列表自动确定数组大小。

访问数组元素

数组元素通过索引访问,索引从0开始。例如,对于一个名为arr的一维数组,arr[0]表示第一个元素,arr[1]表示第二个元素,以此类推。

数组与指针的关系

指针数组与动态数据访问-CSDN博客

注意事项

1.数组的大小一旦确定,在程序运行期间不能改变。
2.访问超出数组范围的元素会导致未定义行为,可能会导致程序崩溃或产生不可预料的结果。
3.C语言不进行边界检查,因此程序员需要自己确保不会发生越界访问。

数组是C语言中最基本的数据结构之一,广泛应用于各种编程场景中,理解数组的工作原理和使用方法对于编写高效的C程序至关重要。

编程实例

1. 基础操作

示例1:数组初始化、遍历与求和

#include <stdio.h>int main() {int arr[5] = {10, 20, 30, 40, 50}; // 初始化数组int sum = 0;// 遍历数组并求和for (int i = 0; i < 5; i++) {printf("arr[%d] = %d\n", i, arr[i]);sum += arr[i];}printf("数组元素总和:%d\n", sum);return 0;
}

输出:

arr[0] = 10
arr[1] = 20
...
数组元素总和:150

 示例2:查找数组中的最大值

#include <stdio.h>int main() {int arr[] = {3, 7, 2, 9, 5};int max = arr[0]; // 假设第一个元素是最大值int size = sizeof(arr) / sizeof(arr[0]); // 计算数组长度for (int i = 1; i < size; i++) {if (arr[i] > max) {max = arr[i];}}printf("最大值:%d\n", max);return 0;
}

输出:

最大值:9

2. 常见算法

示例3:冒泡排序(升序)

#include <stdio.h>//冒泡排序函数
void bubbleSort(int arr[], int size) {for (int i = 0; i < size - 1; i++) {for (int j = 0; j < size - 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[] = {5, 3, 8, 1, 2};int size = sizeof(arr) / sizeof(arr[0]);bubbleSort(arr, size);printf("排序后数组:");for (int i = 0; i < size; i++) {printf("%d ", arr[i]);}return 0;
}

输出:

排序后数组:1 2 3 5 8

示例4:二维数组(矩阵转置)

#include <stdio.h>#define ROWS 3
#define COLS 3int main() {int matrix[ROWS][COLS] = {{1, 2, 3}, {4, 5, 6}, {7, 8, 9}};int transposed[COLS][ROWS];// 转置矩阵for (int i = 0; i < ROWS; i++) {for (int j = 0; j < COLS; j++) {transposed[j][i] = matrix[i][j];}}// 打印转置结果printf("转置矩阵:\n");for (int i = 0; i < COLS; i++) {for (int j = 0; j < ROWS; j++) {printf("%d ", transposed[i][j]);}printf("\n");}return 0;
}

输出:

转置矩阵:
1 4 7 
2 5 8 
3 6 9 

实际应用

示例5:动态数组(使用指针)

#include <stdio.h>
#include <stdlib.h>int main() {int size;printf("输入数组大小:");scanf("%d", &size);// 动态分配内存int *arr = (int *)malloc(size * sizeof(int));if (arr == NULL) {printf("内存分配失败!");return 1;}// 输入元素for (int i = 0; i < size; i++) {printf("输入元素 %d:", i);scanf("%d", &arr[i]);}// 输出元素printf("动态数组内容:");for (int i = 0; i < size; i++) {printf("%d ", arr[i]);}free(arr); // 释放内存return 0;
}

示例6:字符串数组(统计元音字母)

#include <stdio.h>
#include <string.h>int main() {char str[] = "Hello, World!";int vowels = 0;for (int i = 0; i < strlen(str); i++) {char c = str[i];if (c == 'a' || c == 'e' || c == 'i' || c == 'o' || c == 'u' ||c == 'A' || c == 'E' || c == 'I' || c == 'O' || c == 'U') {vowels++;}}printf("元音字母数量:%d\n", vowels);return 0;
}

输出:

元音字母数量:3

4. 高级技巧

示例7:数组作为函数参数

#include <stdio.h>// 函数参数传递数组(本质是指针)
void printArray(int arr[], int size) {for (int i = 0; i < size; i++) {printf("%d ", arr[i]);}
}int main() {int arr[] = {10, 20, 30, 40, 50};int size = sizeof(arr) / sizeof(arr[0]);printArray(arr, size);return 0;
}

示例8:数组越界问题(错误示例)

#include <stdio.h>int main() {int arr[3] = {1, 2, 3};arr[3] = 4; // 越界访问,可能导致程序崩溃或数据损坏printf("%d", arr[3]);return 0;
}

警告: 数组越界是未定义行为(UB),需严格避免!

5. 应用场景

示例9:学生成绩统计

#include <stdio.h>int main() {int scores[5] = {85, 92, 78, 90, 88};int total = 0;float average;for (int i = 0; i < 5; i++) {total += scores[i];}average = (float)total / 5;printf("总分:%d\n平均分:%.2f\n", total, average);return 0;
}

示例10:反转数组

#include <stdio.h>void reverseArray(int arr[], int size) {int start = 0;int end = size - 1;while (start < end) {int temp = arr[start];arr[start] = arr[end];arr[end] = temp;start++;end--;}
}int main() {int arr[] = {1, 2, 3, 4, 5};int size = sizeof(arr) / sizeof(arr[0]);reverseArray(arr, size);printf("反转后的数组:");for (int i = 0; i < size; i++) {printf("%d ", arr[i]);}return 0;
}

总结

  • 数组核心操作:遍历、查找、排序、动态内存分配。

  • 注意点:数组越界、内存管理(动态数组)、多维数组的维度计算。

  • 应用方向:数据处理、字符串操作、算法实现(如排序、搜索)。

通过以上实例,可以逐步掌握数组在C语言中的灵活使用!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/10987.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

neo4j入门

文章目录 neo4j版本说明部署安装Mac部署docker部署 neo4j web工具使用数据结构图数据库VS关系数据库 neo4j neo4j官网Neo4j是用ava实现的开源NoSQL图数据库。Neo4作为图数据库中的代表产品&#xff0c;已经在众多的行业项目中进行了应用&#xff0c;如&#xff1a;网络管理&am…

JVM-运行时数据区

JVM的组成 运行时数据区-总览 Java虚拟机在运行Java程序过程中管理的内存区域&#xff0c;称之为运行时数据区。 《Java虚拟机规范》中规定了每一部分的作用 运行时数据区-应用场景 Java的内存分成哪几部分&#xff1f; Java内存中哪些部分会内存溢出&#xff1f; JDK7 和J…

Java篇之继承

目录 一. 继承 1. 为什么需要继承 2. 继承的概念 3. 继承的语法 4. 访问父类成员 4.1 子类中访问父类的成员变量 4.2 子类中访问父类的成员方法 5. super关键字 6. super和this关键字 7. 子类构造方法 8. 代码块的执行顺序 9. protected访问修饰限定符 10. 继承方式…

leetcode——验证二叉搜索树(java)

给你一个二叉树的根节点 root &#xff0c;判断其是否是一个有效的二叉搜索树。 有效 二叉搜索树定义如下&#xff1a; 节点的左子树只包含小于当前节点的数。 节点的右子树只包含 大于 当前节点的数。 所有左子树和右子树自身必须也是二叉搜索树。 示例 1&#xff1a; 输入…

家居EDI:Hom Furniture EDI需求分析

HOM Furniture 是一家成立于1977年的美国家具零售商&#xff0c;总部位于明尼苏达州。公司致力于提供高品质、时尚的家具和家居用品&#xff0c;满足各种家庭和办公需求。HOM Furniture 以广泛的产品线和优质的客户服务在市场上赢得了良好的口碑。公司经营的产品包括卧室、客厅…

Spring Boot + Facade Pattern : 通过统一接口简化多模块业务

文章目录 Pre概述在编程中&#xff0c;外观模式是如何工作的&#xff1f;外观设计模式 UML 类图外观类和子系统的关系优点案例外观模式在复杂业务中的应用实战运用1. 项目搭建与基础配置2. 构建子系统组件航班服务酒店服务旅游套餐服务 3. 创建外观类4. 在 Controller 中使用外…

八、Spring Boot 日志详解

目录 一、日志的用途 二、日志使用 2.1 打印日志 2.1.1 在程序中获取日志对象 2.1.2 使用日志对象打印日志 2.2、日志框架介绍 2.2.1 门面模式(外观模式) 2.2.2 门面模式的实现 2.2.3 SLF4J 框架介绍 2.3 日志格式的说明 2.4 日志级别 2.4.1 日志级别的分类 2.4.2…

创建前端项目的方法

目录 一、创建前端项目的方法 1.前提&#xff1a;安装Vue CLI 2.方式一&#xff1a;vue create项目名称 3.方式二&#xff1a;vue ui 二、Vue项目结构 三、修改Vue项目端口号的方法 一、创建前端项目的方法 1.前提&#xff1a;安装Vue CLI npm i vue/cli -g 2.方式一&…

(leetcode 213 打家劫舍ii)

代码随想录&#xff1a; 将一个线性数组换成两个线性数组&#xff08;去掉头&#xff0c;去掉尾&#xff09; 分别求两个线性数组的最大值 最后求这两个数组的最大值 代码随想录视频 #include<iostream> #include<vector> #include<algorithm> //nums:2,…

【Python】第七弹---Python基础进阶:深入字典操作与文件处理技巧

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】【C详解】【Linux系统编程】【MySQL】【Python】 目录 1、字典 1.1、字典是什么 1.2、创建字典 1.3、查找 key 1.4、新增/修改元素 1.5、删除元素 1.6、遍历…

本地部署DeepSeek开源多模态大模型Janus-Pro-7B实操

本地部署DeepSeek开源多模态大模型Janus-Pro-7B实操 Janus-Pro-7B介绍 Janus-Pro-7B 是由 DeepSeek 开发的多模态 AI 模型&#xff0c;它在理解和生成方面取得了显著的进步。这意味着它不仅可以处理文本&#xff0c;还可以处理图像等其他模态的信息。 模型主要特点:Permalink…

BW AO/工作簿权限配置

场景&#xff1a; 按事业部配置工作簿权限&#xff1b; 1、创建用户 事务码&#xff1a;SU01&#xff0c;用户主数据的维护&#xff0c;可以创建、修改、删除、锁定、解锁、修改密码等 用户设置详情页 2、创建权限角色 用户的权限菜单是通过权限角色分配来实现的 2.1、自定…

jstat命令详解

jstat 用于监视虚拟机运行时状态信息的命令&#xff0c;它可以显示出虚拟机进程中的类装载、内存、垃圾收集、JIT 编译等运行数据。 命令的使用格式如下。 jstat [option] LVMID [interval] [count]各个参数详解&#xff1a; option&#xff1a;操作参数LVMID&#xff1a;本…

3.Spring-事务

一、隔离级别&#xff1a; 脏读&#xff1a; 一个事务访问到另外一个事务未提交的数据。 不可重复读&#xff1a; 事务内多次查询相同条件返回的结果不同。 幻读&#xff1a; 一个事务在前后两次查询同一个范围的时候&#xff0c;后一次查询看到了前一次查询没有看到的行。 二…

MYSQL--一条SQL执行的流程,分析MYSQL的架构

文章目录 第一步建立连接第二部解析 SQL第三步执行 sql预处理优化阶段执行阶段索引下推 执行一条select 语句中间会发生什么&#xff1f; 这个是对 mysql 架构的深入理解。 select * from product where id 1;对于mysql的架构分层: mysql 架构分成了 Server 层和存储引擎层&a…

ReentrantReadWriteLock源码分析

文章目录 概述一、状态位设计二、读锁三、锁降级机制四、写锁总结 概述 ReentrantReadWriteLock&#xff08;读写锁&#xff09;是对于ReentranLock&#xff08;可重入锁&#xff09;的一种改进&#xff0c;在可重入锁的基础上&#xff0c;进行了读写分离。适用于读多写少的场景…

51单片机开发:温度传感器

温度传感器DS18B20&#xff1a; 初始化时序图如下图所示&#xff1a; u8 ds18b20_init(void){ds18b20_reset();return ds18b20_check(); }void ds18b20_reset(void){DS18B20_PORT 0;delay_10us(75);DS18B20_PORT 1;delay_10us(2); }u8 ds18b20_check(void){u8 time_temp0;wh…

vue2项目(一)

项目介绍 电商前台项目 技术架构&#xff1a;vuewebpackvuexvue-routeraxiosless.. 封装通用组件登录注册token购物车支付项目性能优化 一、项目初始化 使用vue create projrct_vue2在命令行窗口创建项目 1.1、脚手架目录介绍 ├── node_modules:放置项目的依赖 ├──…

labelme_json_to_dataset ValueError: path is on mount ‘D:‘,start on C

这是你的labelme运行时label照片的盘和保存目的地址的盘不同都值得报错 labelme_json_to_dataset ValueError: path is on mount D:,start on C 只需要放一个盘但可以不放一个目录

物联网 STM32【源代码形式-使用以太网】连接OneNet IOT从云产品开发到底层MQTT实现,APP控制 【保姆级零基础搭建】

物联网&#xff08;IoT&#xff09;‌是指通过各种信息传感器、射频识别技术、全球定位系统、红外感应器等装置与技术&#xff0c;实时采集并连接任何需要监控、连接、互动的物体或过程&#xff0c;实现对物品和过程的智能化感知、识别和管理。物联网的核心功能包括数据采集与监…