23、【数组】对角线遍历(C++版)

题目描述

在这里插入图片描述

题目分析

对一个3×3型数组的对角线遍历,重点在于对于数组索引的分析,首先来看一下上述图中,遍历索引的顺序

0,0					// 第一趟
0,1 1,0				// 第二趟
2,0 1,1 0,2			// 第三趟
1,2 2,1				// 第四趟
2,2					// 第五趟

设行索引编号为x,列索引编号为y,趟数值为z。
首先,从趟数和行列索引编号的关系上,可发现在对角线遍历时,
x + y = z - 1恒成立。因此,便可将此公式作为我们的遍历过程的便界条件。

然后,再从每一趟的情况来看,


第一趟,0,0
第二趟,0,1 1,0,x先为0,然后再为1,过程中x逐渐增大,y逐渐减小;
第三趟,2,0 1,1 0,2,x先为2,然后再为1,然后再为0,过程中x逐渐减小,y逐渐增大;
第四趟,1,2 2,1,x先为1,再为2,过程中x逐渐增大,y逐渐减小;
第五趟,2 2


可发现在2,4时,x先小后大,y先大后小,在3时,x先大后小,y先小后大。
那么我们假设,在奇数次的趟数时,均为x先大后小,y先小后大。在偶数次趟数时,均为x先小后大,y先大后小。

参考文章:
【对角线遍历】 分析题目-找准规律-代码清晰易读-不要让自己迷失在随意的ifelse中

代码实现

vector<int> findDiagonalOrder(vector<vector<int>>& matrix){
	vector<int> nums;
	int m = matrix.size();
	if(m == 0)		return nums;
	int n = matrix.size();
	if(n == 0)		return nums;

	bool bXFlag = true;		// 作为开关,控制数值的初始化,初始化为奇数趟次数的情况还是偶数趟次数的情况
	for(int i = 0; i < m + n; i++){
		// 为true时,初始化为奇数躺次数的情况;为false时,初始化为偶数趟次数的情况。
		int pm = bXFlag ? m : n;		
		int pn = bXFlag ? n : m;

		int x = (i < pm) ? i : pm - 1;
		int y = i - x;

		while(x >= 0 && y < pn){
			nums.push_back(bXFlag ? matrix[x][y] : matrix[y][x]);
		}
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

辰阳星宇

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值