顺时针打印数组,美丽版

今天看到一段代码,顺时针打印数组。写得太美了,简洁明了,几乎不用任何注释。

转过来,原来是java版的,我改成了C++版。

 

 1     void PrintMatrixClockWise()
 2     {
 3         int m = 5;
 4         int n = 4;
 5         int val[4][5] = 
 6         {    
 7             {1,    2,    3,    4,    5 },
 8             {6,    7,    8,    9,    1 },
 9             {11,   12,   13,   14,   15},
10             {16,   17,   18,   19,   20}
11         };
12 
13         int colMin = 0;
14         int colMax = m;
15         int rowMin = 0;
16         int rowMax = n;
17 
18         while(colMin < colMax && rowMin < rowMax)
19         {
20             for(int i = colMin; i < colMax; i++)
21                 cout << (val[rowMin][i]) << " ";
22             cout << endl;
23             rowMin++;
24 
25             for(int i = rowMin; i < rowMax; i++)
26                 cout << (val[i][colMax-1]) << " ";
27             cout << endl;
28             colMax--;
29 
30             for(int i = colMax-1; i >= colMin; i--)
31                 cout << (val[rowMax-1][i]) << " ";
32             cout << endl;
33             rowMax--;
34 
35             for(int i = rowMax-1; i >= rowMin; i--)
36                 cout << (val[i][colMin]) << " ";
37             cout << endl;
38             colMin++;
39         }
40     }

转载于:https://www.cnblogs.com/yayagamer/archive/2012/06/24/2560241.html

在C语言中,顺时针螺旋打印数组是一种常见的二维数组遍历技巧,通常用于矩阵显示或者数据可视化。它的基本思路是从左上角开始,按照右->下->左->上这样的顺序逐层遍历。以下是步骤说明: 1. 首先初始化两个指针 `i` 和 `j` 分别指向数组的第一行和第一列。 2. 使用两层循环: - 内层循环从 `j` 到 `n-1` (`n` 是数组的列数),每次打印当前行的一个元素。 - 当内层循环结束后,外层循环将向右移动到下一个未访问过的行,`i++`。 - 然后再执行内层循环,这次从 `i` 到 `n`,每次打印下一列的元素。 - 这样,每完成一层,就将指针向右、向下移动一格,直到遍历完整个矩阵。 下面是一个简单的C语言函数示例,展示如何实现这个功能: ```c #include <stdio.h> void spiralPrint(int m, int n, int arr[m][n]) { int i = 0, j = 0; // 初始化指针 while (i < m && j < n) { // 打印第一行 for (int k = j; k < n; ++k) { printf("%d ", arr[i][k]); } i++; // 打印最后一列 for (int k = i; k < m; ++k) { printf("%d ", arr[k][n - 1]); } n--; // 如果还有剩余的行 if (i < m) { // 打印倒数第二行 for (int k = n - 1; k >= j; --k) { printf("%d ", arr[m - 1][k]); } m--; } // 如果还有剩余的列 if (j < n) { // 打印倒数第一列 for (int k = m - 1; k >= i; --k) { printf("%d ", arr[k][j]); } j++; } } } // 测试 int main() { int arr[4][4] = {{1, 2, 3, 4}, {5, 6, 7, 8}, {9, 10, 11, 12}, {13, 14, 15, 16}}; spiralPrint(4, 4, arr); return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值