順時(shí)針打印矩陣

順時(shí)針打印矩陣

我的想法就是先定下四個(gè)角的坐標(biāo),然后按行和列打印

這里很重要的是,如果你想用x,y來代表坐標(biāo),一點(diǎn)不要把數(shù)組的規(guī)律和坐標(biāo)系搞混淆了,這樣可能你打印出來是反的.
這里我是這樣做的:
數(shù)組的下標(biāo)是:

a00 a01 a02...
a10 a11 a12..
a20 a21 a22...

所以我使用x代表第一個(gè)下標(biāo),y代表第二個(gè)下標(biāo)
a[x][y]

形象的:

二維數(shù)組

大家可以根據(jù)這個(gè)圖:

  • 確定四個(gè)角的"坐標(biāo)"
  • 確定打印的順序

這是驅(qū)動(dòng)函數(shù):

//judge if input legall!!!
void print_left_right(int a[][100], int start, int end,int y);//x goes up
void print_right_left(int a[][100], int start, int end,int y);//x goes down
void print_up_down(int a[][100], int start, int end,int x);
void print_down_up(int a[][100], int start, int end,int x);
//print an matrix by circle
//the matrix is m*n
void print_matrix(int a[][100], int m, int n)
{
    int startX, startY,endX,endY;
    startX = 0;
    startY = 0;
    endX = m - 1;
    endY = n - 1;
    while (startX < endX && startY<endY)
    {
        print_left_right(a, startY, endY,startX);
        print_up_down(a, startX + 1, endX, endY);
        print_right_left(a, endY - 1, startY, endX);
        print_down_up(a, endX - 1, startX + 1, startY);

        startX++;
        endX--;
        startY++;
        endY--;
    }//when breaks,one line remains
    if (endX == startX&&endY != startY)
    {
        //std::cout << "print between x=" << endX << " y=" << startY << " & " << endY;
        print_left_right(a, startY, endY, startX);
    }
    else if (endX != startX&&endY == startY)
    {
        //std::cout << "print between x=" << endX << " y=" << startY << " & " << endY;
        print_up_down(a, startX, endX, startY);
    }
    else if (startX == endX&&startY == endY)
        std::cout << a[startX][startY];
}
  • 每打印一圈,坐標(biāo)就往里面縮小一圈
  • 判斷臨界值;
  • 處理行和列相同和不相同的情況
  • 四個(gè)打印函數(shù)要判斷輸入的參數(shù)是否合法


接著寫具體的函數(shù):

void print_left_right(int a[][100], int start, int end, int x)//y goes up
{
    if ( start > end)
        return;
    for (int i = start; i <= end; i++)
    {
        std::cout << a[x][i] << " ";
    }
}
void print_right_left(int a[][100], int start, int end, int x)//x goes down
{
    if (start < end)
        return;
    for (int i = start; i >= end; i--)
    {
        std::cout << a[x][i] << " ";
    }
}
void print_up_down(int a[][100], int start, int end, int y)
{
    if ( start > end)
        return;
    for (int i = start; i <= end; i++)
    {
        std::cout << a[i][y] << " ";
    }
}
void print_down_up(int a[][100], int start, int end, int y)
{
    if (start < end)
        return;
    for (int i = start; i >= end; i--)
    {
        std::cout << a[i][y] << " ";
    }
}
void getMatrix(int a[][100],int m,int n)
{
    std::cout << "please input a matrix:" << "\n";
    for (int i = 0; i < m; i++)
    {
        for (int j = 0; j < n; j++)
            std::cin >> a[i][j];
    }
    
}
int main()
{
    int a[100][100];
    int m, n;
    std::cout << "please input number of hang:" << "\n";
    std::cin >> m;
    std::cout << "please input number of lie:" << "\n";
    std::cin >> n;
    
    //
     getMatrix(a,m, n);
     print_matrix(a, m, n);

     
}

其實(shí)寫這個(gè)的時(shí)候我出了好多錯(cuò)誤,都是淚啊
比如手抖寫錯(cuò)了,一直沒改,潛伏到最后才發(fā)現(xiàn):

while (startX <= endX || startY >= startY)

尼瑪?shù)诙€(gè)判斷也是醉了

還有一點(diǎn)就是while的出口條件,我這樣寫可以,但是也可以是其他的,大家自己在紙上寫寫畫畫就清楚了

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 題目 輸入一個(gè)矩陣,按照從外向里以順時(shí)針的順序依次打印出每一個(gè)數(shù)字,例如,如果輸入如下矩陣: 1 2 3 4 5 ...
    wuzhiguo閱讀 1,330評(píng)論 0 0
  • 順時(shí)針打印矩陣 題目描述 輸入一個(gè)矩陣,按照從外向里以順時(shí)針的順序依次打印出每一個(gè)數(shù)字,例如,如果輸入如下矩陣: ...
    echoVic閱讀 736評(píng)論 0 2
  • 1.設(shè)置四個(gè)變量,左,右,上,下 來記錄當(dāng)前打印到哪個(gè)邊界 2外循環(huán)里包裹從右到左,從上到下,從右到左,從下到上,...
    senninha閱讀 233評(píng)論 0 0
  • 思路:一圈一圈打印。打印繼續(xù)的條件,每圈的最左上角的點(diǎn)(StartX,StartY)滿足*StartX x 2<r...
    shuixingge閱讀 340評(píng)論 0 0
  • 輸入一個(gè)矩陣,按照從外向里以順時(shí)針的順序依次打印出每一個(gè)數(shù)字,例如,如果輸入如下矩陣: 1 2 3 4 5 6 7...
    鴻雁長(zhǎng)飛光不度閱讀 230評(píng)論 0 0

友情鏈接更多精彩內(nèi)容