閱讀679 返回首頁    go 阿裏雲 go 技術社區[雲棲]


2012年藍橋杯【初賽試題】 轉方陣

問題描述:


    對一個方陣轉置,就是把原來的行號變列號,原來的列號變行號
    例如,如下的方陣:
 1  2  3  4
 5  6  7  8
 9 10 11 12
13 14 15 16


    轉置後變為:


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


    但,如果是對該方陣順時針旋轉(不是轉置),卻是如下結果:


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


    下麵的代碼實現的功能就是要把一個方陣順時針旋轉。

[cpp] view plaincopy在CODE上查看代碼片派生到我的代碼片
  1. void rotate(int* x, int rank)  
  2. {  
  3.     int* y = (int*)malloc(___________________);  // 填空  
  4.     for(int i=0; i<rank * rank; i++)  
  5.     {  
  6.         y[_________________________] = x[i];  // 填空  
  7.     }  
  8.     for(i=0; i<rank*rank; i++)  
  9.     {  
  10.         x[i] = y[i];  
  11.     }  
  12.     free(y);  
  13. }  
  14. int main(int argc, char* argv[])  
  15. {  
  16.     int x[4][4] = {{1,2,3,4},{5,6,7,8},{9,10,11,12},{13,14,15,16}};  
  17.     int rank = 4;  
  18.     rotate(&x[0][0], rank);  
  19.     for(int i=0; i<rank; i++)  
  20.     {  
  21.         for(int j=0; j<rank; j++)  
  22.         {  
  23.             printf("%4d", x[i][j]);  
  24.         }  
  25.         printf("\n");  
  26.     }  
  27.     return 0;  
  28. }  


請分析代碼邏輯,並推測劃線處的代碼。
答案寫在 “解答.txt” 文件中


第一個考察動態數組的建立方法,以為動態數組建立方法為:

(數組長度為n)

#include <malloc.h>..................頭文件
int main(){
int n;
scanf("%d", &n);
int *shzu = (int*)malloc(sizeof(int)*n);...............定義
… …
free(shuzu);............釋放
所用到的函數:
                     malloc,free
     所在的頭文件:stdlib.h
    使用格式:
{
    int n;
    int *a;
    scanf("%d",&n);
    a=(int*)malloc(n*sizeof(int));//
    ......
    free(a);
}


動態創建二維數組和動態創建一維數組類似,隻不過數組名是二級指針:
c語言:
{
    int n;
    int **a;
    scanf("%d",&n);
    a=(int**)malloc(n*sizeof(int*));//
    for(int i=0;i<n;++i) a[i]=(int*)malloc(n*sizeof(int));
    for(int i=0;i<n;++i) free(a[i]);
}
c++:
{
    int n;
    int **a;
    cin>>n;
    *a=new int*[n];//
    for(int i=0;i<n;++i) a[i]=new int[n];//
    for(int i=0;i<n;++i) delete a[i];//回收內存
}
所以第一個空為rank*rank*sizeof(int)


第二個填空考察x與y的賦值關係:

y[j,i]=x[i,j];

x[m]<=========>x[m/rank,m%rank]<=============>x[i,j]

y[n]<=========>y[(m%rank)*rank+m/rank]<========>y[j,i]

所以,轉置時第二個空為:(m%rank)*rank+m/rank,

順時針旋轉時第二個空的內容是(m%rank)*rank+(rank-m/rank-1)

 

答案:(i%rank)*rank+(rank-i/rank-1)



最後更新:2017-04-03 12:55:13

  上一篇:go Flume-ng ThriftSource原理分析
  下一篇:go 單例模式補充(四)