鱼C论坛

 找回密码
 立即注册
查看: 450|回复: 1

[已解决]动态内存的应用与二维数组

[复制链接]
发表于 2024-10-8 21:09:37 From FishC Mobile | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 CIJUNBUGUILU 于 2024-10-8 21:19 编辑

如何实现一个3*3的阶梯二维数组
[ ]     访问[0][0]可以访问[0][1] , [0][2]越界
[ ] [ ]      同上,访问[1][2]越界
[ ] [ ] [ ]
最佳答案
2024-10-8 21:13:41
要实现一个 3\*3 的阶梯二维数组,并探讨访问越界的问题,我们可以从 C 语言的动态内存分配开始。阶梯数组(Jagged Array)指的是每一行的列数可能不同。

### 实现一个 3\*3 的阶梯二维数组:

  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. int main() {
  4.     int rows = 3;
  5.     int* array[3];

  6.     // 动态分配内存,为每行分配不同列数
  7.     for (int i = 0; i < rows; i++) {
  8.         array[i] = (int*)malloc((i + 1) * sizeof(int));
  9.     }
  10.    
  11.     // 初始化数组
  12.     for (int i = 0; i < rows; i++) {
  13.         for (int j = 0; j <= i; j++) {
  14.             array[i][j] = i * 10 + j;
  15.         }
  16.     }

  17.     // 打印数组
  18.     for (int i = 0; i < rows; i++) {
  19.         for (int j = 0; j <= i; j++) {
  20.             printf("%d ", array[i][j]);
  21.         }
  22.         printf("\n");
  23.     }

  24.     // 释放内存
  25.     for (int i = 0; i < rows; i++) {
  26.         free(array[i]);
  27.     }

  28.     return 0;
  29. }
复制代码


### 访问与越界问题:

1. **正常访问**:你可以通过 `array[i][j]` 访问分配的内存,其中 `0 <= i < 3` 且 `0 <= j <= i`。

2. **越界访问**:
   - 如果你尝试访问 `array[2][3]` ,会出现越界,因为`array[2]`仅分配到 `array[2][2]`。
   - 若对未分配内存进行写操作,可能会覆盖其他内存区域,导致不可预测的行为,甚至程序崩溃。

每次动态分配内存后,务必确保正确访问和及时释放内存,以免内存泄漏和潜在的错误。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2024-10-8 21:13:41 | 显示全部楼层    本楼为最佳答案   
要实现一个 3\*3 的阶梯二维数组,并探讨访问越界的问题,我们可以从 C 语言的动态内存分配开始。阶梯数组(Jagged Array)指的是每一行的列数可能不同。

### 实现一个 3\*3 的阶梯二维数组:

  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. int main() {
  4.     int rows = 3;
  5.     int* array[3];

  6.     // 动态分配内存,为每行分配不同列数
  7.     for (int i = 0; i < rows; i++) {
  8.         array[i] = (int*)malloc((i + 1) * sizeof(int));
  9.     }
  10.    
  11.     // 初始化数组
  12.     for (int i = 0; i < rows; i++) {
  13.         for (int j = 0; j <= i; j++) {
  14.             array[i][j] = i * 10 + j;
  15.         }
  16.     }

  17.     // 打印数组
  18.     for (int i = 0; i < rows; i++) {
  19.         for (int j = 0; j <= i; j++) {
  20.             printf("%d ", array[i][j]);
  21.         }
  22.         printf("\n");
  23.     }

  24.     // 释放内存
  25.     for (int i = 0; i < rows; i++) {
  26.         free(array[i]);
  27.     }

  28.     return 0;
  29. }
复制代码


### 访问与越界问题:

1. **正常访问**:你可以通过 `array[i][j]` 访问分配的内存,其中 `0 <= i < 3` 且 `0 <= j <= i`。

2. **越界访问**:
   - 如果你尝试访问 `array[2][3]` ,会出现越界,因为`array[2]`仅分配到 `array[2][2]`。
   - 若对未分配内存进行写操作,可能会覆盖其他内存区域,导致不可预测的行为,甚至程序崩溃。

每次动态分配内存后,务必确保正确访问和及时释放内存,以免内存泄漏和潜在的错误。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-5-10 08:25

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表