C语言一维数组与二维数组详解及代码实例

简介: C语言一维数组与二维数组详解及代码实例

一、引言


在C语言中,数组是一种重要的数据结构,它允许我们存储多个相同类型的元素,并通过索引来访问这些元素。一维数组是最简单的数组形式,用于存储线性数据;而二维数组则用于存储表格型数据,如矩阵。本文将详细介绍一维数组和二维数组的基本概念、使用方法和代码实例。


二、一维数组


1.概念

一维数组是由一系列相同类型的元素组成的线性表,每个元素都有一个唯一的索引值,用于标识其在数组中的位置。在C语言中,数组的索引值从0开始。

2.声明与初始化

声明一维数组时,需要指定数组的类型和大小。例如,声明一个包含10个整数的数组可以写作:

int array[10];

初始化数组时,可以在声明时直接为数组元素赋值。例如:

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

3.访问与修改

通过索引值可以访问和修改数组中的元素。例如,访问数组中的第一个元素可以写作array[0],修改数组中的第三个元素为10可以写作array[2] = 10。

4.代码实例

以下是一个简单的一维数组代码实例,用于计算数组中所有元素的和:

#include <stdio.h>
int main() { 
int array[5] = {1, 2, 3, 4, 5}; 
int sum = 0; 
for (int i = 0; i < 5; i++) { 
sum += array[i]; 
} 
printf("The sum of array elements is: %d\n", sum); 
return 0; 
}


三、二维数组


1.概念

二维数组是由多个一维数组组成的表格型数据结构,每个一维数组称为二维数组的行,每个元素称为二维数组的元素。在C语言中,二维数组的索引值也从0开始。

2.声明与初始化

声明二维数组时,需要指定数组的行数和列数。例如,声明一个3行4列的整数二维数组可以写作:

int matrix[3][4];

初始化二维数组时,可以在声明时直接为数组元素赋值。例如:

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

3.访问与修改

通过行索引和列索引可以访问和修改二维数组中的元素。例如,访问二维数组中第一行第二列的元素可以写作matrix[0][1],修改二维数组中第二行第三列的元素为10可以写作matrix[1][2] = 10。

4.代码实例

以下是一个简单的二维数组代码实例,用于计算矩阵的转置:

#include <stdio.h>
#define ROWS 2 
#define COLS 3 
void transpose(int matrix[ROWS][COLS], int transposeMatrix[COLS][ROWS]) { 
for (int i = 0; i < ROWS; i++) { 
for (int j = 0; j < COLS; j++) { 
transposeMatrix[j][i] = matrix[i][j]; 
} 
} 
} 
int main() { 
int matrix[ROWS][COLS] = {{1, 2, 3}, {4, 5, 6}}; 
int transposeMatrix[COLS][ROWS]; 
transpose(matrix, transposeMatrix); 
printf("Original matrix:\n"); 
for (int i = 0; i < ROWS; i++) { 
for (int j = 0; j < COLS; j++) { 
printf("%d ", matrix[i][j]); 
} 
printf("\n"); 
} 
printf("Transposed matrix:\n"); 
for (int i = 0; i < COLS; i++) { 
for (int j = 0; j < ROWS; j++) { 
printf("%d ", transposeMatrix[i][j]); 
} 
printf("\n"); 
} 
return 0; 
}

以上代码首先定义了一个二维数组matrix,然后定义了一个用于存储转置矩阵的二维数组transposeMatrix。transpose函数用于计算矩阵的转置,最后在主函数中输出原始矩阵和转置矩阵。

相关文章
|
7天前
|
安全 C语言
在C语言中,正确使用运算符能提升代码的可读性和效率
在C语言中,运算符的使用需要注意优先级、结合性、自增自减的形式、逻辑运算的短路特性、位运算的类型、条件运算的可读性、类型转换以及使用括号来明确运算顺序。掌握这些注意事项可以帮助编写出更安全和高效的代码。
20 4
|
21天前
|
存储 编译器 C语言
【C语言基础考研向】09 一维数组
数组是一种有序集合,用于存储相同类型的数据,便于统一操作与管理。例如,将衣柜底层划分为10个格子存放鞋子,便于快速定位。在C语言中,数组定义格式为 `类型说明符数组名[常量表达式];`,如 `int a[10];` 表示定义了一个包含10个整数的数组。数组初始化时可以直接赋值,也可以部分赋值,且数组长度必须固定。数组在内存中连续存储,访问时需注意下标范围,避免越界导致数据异常。数组作为参数传递时,传递的是首地址,修改会影响原数组。
|
21天前
|
存储 C语言
【C语言基础考研向】10 字符数组初始化及传递和scanf 读取字符串
本文介绍了C语言中字符数组的初始化方法及其在函数间传递的注意事项。字符数组初始化有两种方式:逐个字符赋值或整体初始化字符串。实际工作中常用后者,如`char c[10]=&quot;hello&quot;`。示例代码展示了如何初始化及传递字符数组,并解释了为何未正确添加结束符`\0`会导致乱码。此外,还讨论了`scanf`函数读取字符串时忽略空格和回车的特点。
|
24天前
|
存储 算法 C语言
数据结构基础详解(C语言):单链表_定义_初始化_插入_删除_查找_建立操作_纯c语言代码注释讲解
本文详细介绍了单链表的理论知识,涵盖单链表的定义、优点与缺点,并通过示例代码讲解了单链表的初始化、插入、删除、查找等核心操作。文中还具体分析了按位序插入、指定节点前后插入、按位序删除及按值查找等算法实现,并提供了尾插法和头插法建立单链表的方法,帮助读者深入理解单链表的基本原理与应用技巧。
|
24天前
|
存储 C语言
数据结构基础详解(C语言): 栈与队列的详解附完整代码
栈是一种仅允许在一端进行插入和删除操作的线性表,常用于解决括号匹配、函数调用等问题。栈分为顺序栈和链栈,顺序栈使用数组存储,链栈基于单链表实现。栈的主要操作包括初始化、销毁、入栈、出栈等。栈的应用广泛,如表达式求值、递归等场景。栈的顺序存储结构由数组和栈顶指针构成,链栈则基于单链表的头插法实现。
147 3
|
24天前
|
存储 算法 C语言
C语言手撕实战代码_二叉排序树(二叉搜索树)_构建_删除_插入操作详解
这份二叉排序树习题集涵盖了二叉搜索树(BST)的基本操作,包括构建、查找、删除等核心功能。通过多个具体示例,如构建BST、查找节点所在层数、删除特定节点及查找小于某个关键字的所有节点等,帮助读者深入理解二叉排序树的工作原理与应用技巧。此外,还介绍了如何将一棵二叉树分解为两棵满足特定条件的BST,以及删除所有关键字小于指定值的节点等高级操作。每个题目均配有详细解释与代码实现,便于学习与实践。
|
24天前
|
存储 算法 C语言
C语言手撕实战代码_二叉树_构造二叉树_层序遍历二叉树_二叉树深度的超详细代码实现
这段代码和文本介绍了一系列二叉树相关的问题及其解决方案。其中包括根据前序和中序序列构建二叉树、通过层次遍历序列和中序序列创建二叉树、计算二叉树节点数量、叶子节点数量、度为1的节点数量、二叉树高度、特定节点子树深度、判断两棵树是否相似、将叶子节点链接成双向链表、计算算术表达式的值、判断是否为完全二叉树以及求二叉树的最大宽度等。每道题目均提供了详细的算法思路及相应的C/C++代码实现,帮助读者理解和掌握二叉树的基本操作与应用。
|
24天前
|
存储 算法 C语言
C语言手撕实战代码_循环单链表和循环双链表
本文档详细介绍了用C语言实现循环单链表和循环双链表的相关算法。包括循环单链表的建立、逆转、左移、拆分及合并等操作;以及双链表的建立、遍历、排序和循环双链表的重组。通过具体示例和代码片段,展示了每种算法的实现思路与步骤,帮助读者深入理解并掌握这些数据结构的基本操作方法。
|
24天前
|
算法 C语言 开发者
C语言手撕实战代码_单链表
本文档详细介绍了使用C语言实现单链表的各种基本操作和经典算法。内容涵盖单链表的构建、插入、查找、合并及特殊操作,如头插法和尾插法构建单链表、插入元素、查找倒数第m个节点、合并两个有序链表等。每部分均配有详细的代码示例和注释,帮助读者更好地理解和掌握单链表的编程技巧。此外,还提供了判断子链、查找公共后缀等进阶题目,适合初学者和有一定基础的开发者学习参考。
|
24天前
|
存储 算法 C语言
C语言手撕数据结构代码_顺序表_静态存储_动态存储
本文介绍了基于静态和动态存储的顺序表操作实现,涵盖创建、删除、插入、合并、求交集与差集、逆置及循环移动等常见操作。通过详细的C语言代码示例,展示了如何高效地处理顺序表数据结构的各种问题。