C语言解决螺旋矩阵算法问题的代码示例
发布时间:2020-12-16 05:25:53 所属栏目:百科 来源:网络整理
导读:赶集网校招就采用了螺旋输出矩阵作为程序题,要求将矩阵螺旋输出如: 图中6*6矩阵线条所示为输出顺序,如果输出正确的话应该输出1~36有序数字。 我想的是这么做的: #include stdio.h //#define LEN 1 //#define LEN 2 //#define LEN 3 #define LEN 4 void p
赶集网校招就采用了螺旋输出矩阵作为程序题,要求将矩阵螺旋输出如: 图中6*6矩阵线条所示为输出顺序,如果输出正确的话应该输出1~36有序数字。 #include <stdio.h> //#define LEN 1 //#define LEN 2 //#define LEN 3 #define LEN 4 void printClock(int a[][LEN]){//输出函数 int t; int i = 0,m = 0; int j = LEN,n = LEN; while (i <= j || m <= n) { for (t = i; t < j; t++)//输出第m行 { printf("%d ",a[m][t]); } m++; for (t = m; t < n; t++)//输出第j列 { printf("%d ",a[t][j - 1]); } j--; for (t = j - 1; t >= i; t--)//输出第n行 { printf("%d ",a[n - 1][t]); } n--; for (t = n - 1; t >= m; t--)//输出第i列 { printf("%d ",a[t][i]); } i++; } printf("n"); } void main(){ int a[][1] = {1}; int b[][2] = {1,2,4,3 }; int c[][3] = {1,3,8,9,7,6,5 }; int d[][4] = {1,12,13,14,5,11,16,15,10,7 }; int e[][6] = { 1,20,21,22,23,24,19,32,33,34,25,18,31,36,35,26,17,30,29,28,27,11 }; printClock(d); } 分别做向右输出,向下输出,向左输出,向上输出,然后就进入一种循环,直到输出结束 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |