498. Diagonal Traverse

class Solution
{
public:
    vector<int> findDiagonalOrder(vector<vector<int>>& matrix) 
    {
        if(matrix.empty())
        {
            return {};
        }
		vector<int> result;
		bool fromUp = false;  /* false 自下而上 ture 自上而下*/

		int a = 0;
		int b = 0;  //(a,b)  A点

		int c = 0;
		int d = 0;  //(c,d) B点

		int endR = matrix.size() - 1;
		int endC = matrix[0].size() - 1;

       
		while (a != endR + 1)  //a 走到最后一行的时候b到了最后一列
		{
			this->printLevel(matrix,a,b,c,d,fromUp,result);
			a = (b == endC ? a + 1 : a);
			b = (b == endC ? b : b + 1);
			d = (c == endR ? d + 1 : d);
			c = (c == endR ? c : c + 1);


			fromUp = !fromUp;
		}
		return result;
    }
private:
    	/*打印一列*/
	void printLevel(vector<vector<int>>& matrix,int a,int b,int c,int d,bool f,vector<int>& result)
	{
		if (f)
		{
			/*f = true 自上而下的打印矩阵*/
			while (a != c + 1)
			{
				result.push_back(matrix[a][b]);
				a++;
				b--;
			}
		}
		else
		{
			/*f = false 自下而上的打印矩阵*/
			while (c != a - 1)
			{
				result.push_back(matrix[c][d]);
				c--;
				d++;
			}
		}
	}
};
posted @   尚修能的技术博客  阅读(133)  评论(0编辑  收藏  举报
编辑推荐:
· 理解Rust引用及其生命周期标识(下)
· 从二进制到误差:逐行拆解C语言浮点运算中的4008175468544之谜
· .NET制作智能桌面机器人:结合BotSharp智能体框架开发语音交互
· 软件产品开发中常见的10个问题及处理方法
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
阅读排行:
· 2025成都.NET开发者Connect圆满结束
· 在 VS Code 中,一键安装 MCP Server!
· 后端思维之高并发处理方案
· langchain0.3教程:从0到1打造一个智能聊天机器人
· 千万级大表的优化技巧
点击右上角即可分享
微信分享提示