数组是C++程序员的必备基础技能
一、什么是数组?
数组是C++中最基础且重要的数据结构之一,它允许我们在连续内存空间中存储多个相同类型的元素。想象一下它就像超市储物柜,每个格子(元素)都有编号(索引),可以存放物品(数据)。
// 声明一个能存放5个整数的数组
int scores[5];
二、数组核心操作详解
1. 声明与初始化
// 静态初始化
float temperatures[4] = {36.5, 37.0, 36.8};
// 自动推导数组大小
char vowels[] = {'a', 'e', 'i', 'o', 'u'};
// C++11统一初始化
string colors[3] {"红", "绿", "蓝"};
2. 元素访问(重点!)
int primes[5] = {2, 3, 5, 7, 11};
// 获取第三个元素(索引从0开始)
cout << primes[2]; // 输出5
// 修改第四个元素
primes[3] = 17; // 数组变为[2,3,5,17,11]
3. 多维数组实战
// 声明3x3矩阵
int matrix[3][3] = {
{1, 2, 3},
{4, 5, 6},
{7, 8, 9}
};
// 访问第二行第三列元素
cout << matrix[1][2]; // 输出6
三、新手必知的5大易错点
- 数组越界访问
int arr[3] = {10,20,30};
cout << arr[3]; // 危险!实际索引范围是0-2
- 数组长度计算陷阱
int arr[] = {1,2,3};
int length = sizeof(arr)/sizeof(arr[0]); // 正确方式
- 数组不能直接赋值
int a[3] = {1,2,3};
int b[3];
b = a; // 错误!需要逐个元素复制
- 函数传参时的数组退化
void printArray(int arr[]) { // 实际传递的是指针
// 无法在此获取数组长度
}
- 动态数组的坑
int size = 5;
int arr[size]; // C++标准不支持变量作为长度
四、数组应用实战案例
案例1:成绩统计分析
const int STUDENTS = 50;
double grades[STUDENTS];
// 输入成绩
for(int i=0; i<STUDENTS; ++i) {
cin >> grades[i];
}
// 计算平均分
double sum = 0;
for(double g : grades) {
sum += g;
}
cout << "平均分:" << sum/STUDENTS;
案例2:矩阵转置
int matrix[3][3] = {{1,2,3}, {4,5,6}, {7,8,9}};
for(int i=0; i<3; ++i) {
for(int j=i+1; j<3; ++j) {
swap(matrix[i][j], matrix[j][i]);
}
}
五、数组的局限性及替代方案
虽然数组是基础,但在现代C++开发中更推荐:
vector
:动态大小、自动管理内存array
(C++11):固定大小但更安全- 智能指针数组:更好的内存管理
六、学习资源推荐
🔥 交流群:[QQ群1047019254]
总结
数组作为C++的基石,需要重点掌握:
✅ 内存连续存储特性
✅ 索引从0开始的访问方式
✅ 多维数组的内存布局
✅ 与指针的密切关系