之字形打印矩阵

编程入门 行业动态 更新时间:2024-10-17 02:55:02

之字形打印<a href=https://www.elefans.com/category/jswz/34/1769510.html style=矩阵"/>

之字形打印矩阵

#include<iostream>
#define MAXROW 3
#define MAXCOL 4
using namespace std;
//打印之字形矩阵
//压中的点是每条对角线最右上的点(tR,tC)和最左下(dR,dC)的点
//右上点的移动逻辑:每次往左移动,移动不了了往下移动
//左下点的移动逻辑:每次往下移动,移动不了了往右移动
//upToDown:从上往下
void printDiagonal(int m[][MAXCOL],int tR,int tC,int dR, int dC, bool upToDown)
{if(upToDown){while(tR<=dR)cout<<m[tR++][tC--]<<"\t";}else{while(dR>=tR)cout<<m[dR--][dC++]<<"\t";}
}void printSpecialMatrix(int m[][MAXCOL])
{cout<<"==============NEW MATRIX=============="<<endl;int tR=0,tC=0;int dR=0,dC=0;int endR = MAXROW-1,endC = MAXCOL-1;bool upToDown = false;while(tR <= endR){printDiagonal(m,tR,tC,dR, dC, upToDown);tR = tC == endC ? tR + 1 : tR;tC = tC == endC ? tC : tC + 1;dC = dR == endR ? dC + 1 : dC;dR = dR == endR ? dR : dR + 1;upToDown = !upToDown;}cout<<endl;}void printMatrix(int m[][MAXCOL])
{cout<<"==============OLD MATRIX=============="<<endl;for(int i=0;i<MAXROW;i++){for(int j=0;j<MAXCOL;j++)cout<<m[i][j]<<"\t";cout<<endl;}}int main()
{int matrix[MAXROW][MAXCOL] = {{1,2,3,4},{5,6,7,8},{9,10,11,12}};printMatrix(matrix);printSpecialMatrix(matrix);return 0;
}

 

更多推荐

之字形打印矩阵

本文发布于:2024-03-10 21:00:01,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1729019.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:矩阵   之字形

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!