创建一个三维数组

题目:创建一个三维数组,4*4*4个元素,数字随机生成,找出每行最大的数,每面最大的数,以及整个数组中最大的数的地址,具体实现如下:

[cpp]  view plain copy
  1. #include<stdio.h>  
  2. #include<stdlib.h>  
  3. #include<time.h>  
  4.   
  5. void PrintMaxValByIndex(int(*pData)[4][4], int nRows)  
  6. {  
  7.     int * RowMaxVal[4][4] = { 0 };  
  8.     int * PlanMaxVal[4] = { 0 };  
  9.     int nMaxVal = 0;  
  10.     int i = 0;  
  11.     int j = 0;  
  12.     int k = 0;  
  13.     int * pMaxVal = NULL;  
  14.     pMaxVal = &pData[0][0][0];  
  15.     for (i = 0; i < nRows; i++)  
  16.     {  
  17.         PlanMaxVal[i] = &pData[i][0][0];  
  18.   
  19.         for (j = 0; j < 4; j++)  
  20.         {  
  21.             RowMaxVal[i][j] = &pData[i][j][0];  
  22.   
  23.             for (k = 0; k < 4; k++)  
  24.             {  
  25.                 //行  
  26.                 if (pData[i][j][k] > *RowMaxVal[i][j])  
  27.                 {  
  28.                     RowMaxVal[i][j] = &pData[i][j][k];  
  29.                 }  
  30.                 //面  
  31.                 if (pData[i][j][k] > *PlanMaxVal[i])  
  32.                 {  
  33.                     PlanMaxVal[i] = &pData[i][j][k];  
  34.                 }  
  35.                 //体  
  36.                 if (pData[i][j][k] > *pMaxVal)  
  37.                 {  
  38.                     pMaxVal = &pData[i][j][k];  
  39.                 }  
  40.             }  
  41.   
  42.             printf("面%d,行%d的最大值:%d,地址:%p\n", i + 1, j + 1, *RowMaxVal[i][j], RowMaxVal[i][j]);  
  43.         }  
  44.         printf("面%d的最大值:%d,地址:%p\n", i + 1, *PlanMaxVal[i], PlanMaxVal[i]);  
  45.     }  
  46.     printf("数组最大值:%d\,数组最大值地址:%p\n", *pMaxVal, pMaxVal);  
  47. }  
  48.   
  49. void PrintMaxValByPtr(int(*pData)[4][4], int nRows)  
  50. {  
  51.     int * RowMaxVal[4][4] = { 0 };  
  52.     int * PlanMaxVal[4] = { 0 };  
  53.     int nMaxVal = 0;  
  54.     int i = 0;  
  55.     int j = 0;  
  56.     int k = 0;  
  57.     int * pMaxVal = NULL;  
  58.     pMaxVal = *(*(pData + 0)+0)+0;  
  59.     for (i = 0; i < nRows; i++)  
  60.     {  
  61.         *(PlanMaxVal+i) = *(*(pData+i)+0)+0;  
  62.   
  63.         for (j = 0; j < 4; j++)  
  64.         {  
  65.             *(*(RowMaxVal+i)+j) = *(*(pData+i)+j)+0;  
  66.   
  67.             for (k = 0; k < 4; k++)  
  68.             {  
  69.                 //行  
  70.                 if (*(*(*(pData+i)+j)+k) > **(*(RowMaxVal+i)+j))  
  71.                 {  
  72.                     *(*(RowMaxVal+i)+j) = *(*(pData + i) + j) + k;  
  73.                 }  
  74.                 //面  
  75.                 if (*(*(*(pData + i) + j) + k) > **(PlanMaxVal+i))  
  76.                 {  
  77.                     *(PlanMaxVal+i) = *(*(pData + i) + j) + k;  
  78.                 }  
  79.                 //体  
  80.                 if (*(*(*(pData + i) + j) + k) > *pMaxVal)  
  81.                 {  
  82.                     pMaxVal = *(*(pData + i) + j) + k;  
  83.                 }  
  84.             }  
  85.   
  86.             printf("面%d,行%d的最大值:%d,地址:%p\n", i + 1, j + 1, *(*(*(RowMaxVal+i)+j)), *(RowMaxVal+i)+j);  
  87.         }  
  88.         printf("面%d的最大值:%d,地址:%p\n", i + 1, **(PlanMaxVal+i), *(PlanMaxVal+i));  
  89.     }  
  90.     printf("数组最大值:%d\,数组最大值地址:%p\n", *pMaxVal, pMaxVal);  
  91. }  
  92. int main()  
  93. {  
  94.     int Data[4][4][4] = { 0 };  
  95.     int i = 0, j = 0, k = 0;  
  96.     for (i = 0; i < 4; i++)  
  97.     {  
  98.         for (j = 0; j < 4; j++)  
  99.         {  
  100.             for (k = 0; k < 4; k++)  
  101.             {  
  102.                 Data[i][j][k] = rand() % 100;  
  103.             }  
  104.         }  
  105.     }  
  106.     printf("数组元素:\n");  
  107.     for (i = 0; i < 4; i++)  
  108.     {  
  109.         printf("面:%d\n", i + 1);  
  110.         for (j = 0; j < 4; j++)  
  111.         {  
  112.             printf("行:%d\n", j + 1);  
  113.             for (k = 0; k < 4; k++)  
  114.             {  
  115.                 printf("%d  ", Data[i][j][k]);  
  116.             }  
  117.             printf("\n");  
  118.         }  
  119.         printf("\n");  
  120.     }  
  121.     printf("\n");  
  122.     PrintMaxValByIndex(Data,4);  
  123.     PrintMaxValByPtr(Data, 4);  
  124.     system("pause");  
  125.     return 0;  
  126. }  
运行效果如图1所示:

图1 运行效果

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值