#include<iostream>
#define MAXROW 3
#define MAXCOL 4
using namespace std;
//打印之字形矩阵
//压中的点是每条对角线最右上的点(tR,tC)和最左下(dR,dC)的点
//右上点的移动逻辑:每次往左移动,移动不了了往下移动
//左下点的移动逻辑:每次往下移动,移动不了了往右移动
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;
C++ 打印之字形矩阵
最新推荐文章于 2021-12-05 20:17:59 发布
本文展示了如何使用C++编程实现之字形矩阵的打印。通过定义右上和左下两点的移动逻辑,按照从上到下或从下到上的顺序逐行输出矩阵元素,最终形成之字形排列效果。
摘要由CSDN通过智能技术生成