C語(yǔ)言解決螺旋矩陣算法問(wèn)題的代碼示例
更新時(shí)間:2016年04月25日 18:07:15 作者:hzy3774
這篇文章主要介紹了C語(yǔ)言解決螺旋矩陣算法問(wèn)題的代碼示例,螺旋矩陣中的數(shù)字由第一行開(kāi)始到右邊不斷變大,向下變大,向左變大,向上變大,如此循環(huán)...需要的朋友可以參考下
趕集網(wǎng)校招就采用了螺旋輸出矩陣作為程序題,要求將矩陣螺旋輸出如:
圖中6*6矩陣線條所示為輸出順序,如果輸出正確的話應(yīng)該輸出1~36有序數(shù)字。
我想的是這么做的:
#include <stdio.h> //#define LEN 1 //#define LEN 2 //#define LEN 3 #define LEN 4 void printClock(int a[][LEN]){//輸出函數(shù) 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,2,3, 8,9,4, 7,6,5 }; int d[][4] = {1,2, 3, 4, 12,13,14,5, 11,16,15,6, 10, 9, 8,7 }; int e[][6] = { 1, 2, 3, 4, 5, 6, 20,21,22,23,24, 7, 19,32,33,34,25, 8, 18,31,36,35,26, 9, 17,30,29,28,27,10, 16,15,14,13,12,11 }; printClock(d); }
分別做向右輸出,向下輸出,向左輸出,向上輸出,然后就進(jìn)入一種循環(huán),直到輸出結(jié)束
相關(guān)文章
C 語(yǔ)言基礎(chǔ)教程(我的C之旅開(kāi)始了)[五]
C 語(yǔ)言基礎(chǔ)教程(我的C之旅開(kāi)始了)[五]...2007-02-02C語(yǔ)言如何利用輾轉(zhuǎn)相除法求最大公約數(shù)
這篇文章主要介紹了C語(yǔ)言如何利用輾轉(zhuǎn)相除法求最大公約數(shù)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08初學(xué)C++之自定義類(lèi)型名簡(jiǎn)化詳解
下面小編就為就大家?guī)?lái)一篇初學(xué)C++之自定義類(lèi)型名簡(jiǎn)化詳解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-09-09C++使用宏實(shí)現(xiàn)動(dòng)態(tài)庫(kù)加載
開(kāi)發(fā)的時(shí)候,有些項(xiàng)目不能靜態(tài)鏈接動(dòng)態(tài)庫(kù),需要程序運(yùn)行時(shí)加載動(dòng)態(tài)庫(kù)。本文將使用宏來(lái)實(shí)現(xiàn)動(dòng)態(tài)庫(kù)的加載,感興趣的小伙伴可以跟隨小編一起了解一下2022-12-12