OpenJudge計算概論-二維數組右上左下遍歷


/*======================================================================
二維數組右上左下遍歷
總時間限制: 1000ms 內存限制: 65536kB
描述
給定一個row行col列的整數數組array,要求從array[0][0]元素開始,按從左上到右下的對角線順序遍歷整個數組。


輸入
輸入的第一行上有兩個整數,依次為row和col。
余下有row行,每行包含col個整數,構成一個二維整數數組。
(注:輸入的row和col保證0 < row < 100, 0 < col < 100)
輸出
按遍歷順序輸出每個整數。每個整數占一行。
樣例輸入
3 4
1 2  4  7
3 5  8 10
6 9 11 12
樣例輸出
1
2
3
4
5
6
7
8
9
10
11
12


解析:這個題目需要分情況討論行數和列數的大小關系,不同情況不同的處理方式。



上圖當中,以土黃色斜排為分隔界限把矩陣分成了兩個或三個部分,每一部分都需要用兩重循環來完成。其中:外層循環控制斜排的層數,內層循環控制一個斜排內部的單元個數。
上三角部分斜排個數等於列數(row>col)或行數(row<col),下三角部分斜排的個數等於列數
(row>col)或行數(row<col)(當然,其中有些部分需要注意多1或少1的問題,
畢竟分界線所在的斜排可以屬於相鄰的兩個部分當中的任意一個。具體的請看代碼和注釋。)
========================================================================*/
  1 #include<stdio.h>
  2 int main()
  3 {
  4     int row,col,a[100][100],i,j,x,y,t;
  5     freopen("55555.in","r",stdin);
  6     freopen("result.out","w",stdout);
  7     scanf("%d%d",&row,&col);
  8     for(i=0;i<row;i++)
  9     {
 10         for(j=0;j<col;j++)
 11         {
 12             scanf("%d",&a[i][j]);
 13         }
 14     }
 15     /*for(i=0;i<row;i++)
 16     {
 17         for(j=0;j<col;j++)
 18         {
 19             printf("%d ",a[i][j]);
 20         }
 21         printf("\n");
 22     }*/
 23     /**/
 24     if(row>col)
 25     {
 26         t=col;//斜排數量 
 27         for(j=0;j<t;j++)//循環處理每一個斜排 
 28         {
 29             y=j;//每個斜排第一個單元的縱坐標 
 30             x=0;//每個斜排第一個單元的橫坐標 
 31             for(i=0;i<=j;i++,x++,y--)//i控制每個斜排內部單元的個數 
 32             {
 33                 printf("%d\n",a[x][y]);
 34             }
 35         }
 36         
 37         t=row-col;
 38         for(j=1;j<=t;j++)
 39         {
 40             y=col-1;
 41             x=j;
 42             for(i=1;i<=col;i++,x++,y--)
 43             {
 44                 printf("%d\n",a[x][y]);
 45             }
 46         }
 47         
 48         t=col-1;
 49         for(j=t;j>0;j--)
 50         {
 51             y=col-1;
 52             x=row-j;
 53             for(i=0;i<j;i++,x++,y--)
 54             {
 55                 printf("%d\n",a[x][y]);
 56             }
 57         }
 58     }
 59     else if(row<col)
 60     {
 61         t=row;
 62         for(i=1;i<=t;i++)
 63         {
 64             x=0;
 65             y=i-1;
 66             for(j=1;j<=i;j++,x++,y--)
 67             {
 68                 printf("%d\n",a[x][y]);
 69             }
 70         }
 71         
 72         t=col-row;
 73         for(i=1;i<=t;i++)
 74         {
 75             x=0;
 76             y=row+i-1;
 77             for(j=1;j<=row;j++,x++,y--)
 78             {
 79                 printf("%d\n",a[x][y]);
 80             }
 81         }
 82         
 83         t=row-1;
 84         for(i=t;i>0;i--)
 85         {
 86             x=row-i;
 87             y=col-1;
 88             for(j=1;j<=i;j++,x++,y--)
 89             {
 90                 printf("%d\n",a[x][y]);
 91             }
 92         }
 93     }
 94     else
 95     {
 96         t=row;
 97         for(i=1;i<=t;i++)
 98         {
 99             x=0;
100             y=i-1;
101             for(j=1;j<=i;j++,x++,y--)
102             {
103                 printf("%d\n",a[x][y]);
104             }
105         }
106         
107         t=row-1;
108         for(i=t;i>0;i--)
109         {
110             x=row-i;
111             y=col-1;
112             for(j=1;j<=i;j++,x++,y--)
113             {
114                 printf("%d\n",a[x][y]);
115             }
116         }
117     }
118     
119     
120     return 0;
121 }

 

下面是一些測試案例:

1 2 4 7 11 16 22
3 5 8 12 17 23 29
6 9 13 18 24 30 36
10 14 19 25 31 37 43
15 20 26 32 38 44 50
21 27 33 39 45 51 57
28 34 40 46 52 58 64
35 41 47 53 59 65 71
42 48 54 60 66 72 78
49 55 61 67 73 79 85
56 62 68 74 80 86 92
63 69 75 81 87 93 99
70 76 82 88 94 100 105
77 83 89 95 101 106 110
84 90 96 102 107 111 114
91 97 103 108 112 115 117
98 104 109 113 116 118 119

 

1 2 4 7 11 16 22 28 34 40 46 52 58 64 70
3 5 8 12 17 23 29 35 41 47 53 59 65 71 76
6 9 13 18 24 30 36 42 48 54 60 66 72 77 81
10 14 19 25 31 37 43 49 55 61 67 73 78 82 85
15 20 26 32 38 44 50 56 62 68 74 79 83 86 88
21 27 33 39 45 51 57 63 69 75 80 84 87 89 90

 

1 2 4
3 5 7
6 8 10
9 11 12

 

1 2 4 7
3 5 8 11
6 9 12 14
10 13 15 16

 

 這個其實可以考慮把上面的這么多次相類似的代碼寫成子函數。

 

 

(row<col)


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM