C++ 中的对角遍历 II
假设我们有一个名为 nums 的列表列表,我们需要按对角线顺序显示 nums 中的所有元素。
因此,如果输入如下所示:

那么输出将是 [1,6,2,8,7,3,9,4,12,10,5,13,11,14,15,16]
为此,我们将按照以下步骤操作:
定义一个数组 ret
定义一个二维数组 v
初始化 i := 0 时,当 i < nums 的大小,更新(将 i 增加 1),操作:
初始化 j := 0 时,当 j < nums[i] 的大小,更新(将 j 增加 1),操作:
将 { nums[i, j], i, j } 插入 v 的末尾
对数组 v 进行排序
对 v 中的每个 it,操作:
将 it[0] 插入 ret 的末尾
返回 ret
示例
让我们看看以下实现以获得更好的理解:
#include <bits/stdc++.h>
using namespace std;
void print_vector(vector<int> v){
cout << "[";
for(int i = 0; i<v.size(); i++){
cout << v[i] << ", ";
}
cout << "]"<<endl;
}
class Solution {
public:
static bool cmp(vector <int>& a, vector <int>& b ){
int sum1 = a[1] + a[2];
int sum2 = b[1] + b[2];
return sum1 == sum2 ? a[1] > b[1] : sum1 < sum2;
}
vector<int> findDiagonalOrder(vector& nums) {
vector<int> ret;
vector<vector<int> > v;
for (int i = 0; i < nums.size(); i++) {
for (int j = 0; j < nums[i].size(); j++) {
v.push_back({ nums[i][j], i, j });
}
}
sort(v.begin(), v.end(), cmp);
for (auto& it : v)
ret.push_back(it[0]);
return ret;
}
};
main(){
Solution ob;
vector<vector<int>> v = {{1,2,3,4,5},{6,7},{8},{9,10,11},{12,13,14,15,16}};
print_vector(ob.findDiagonalOrder(v));
}输入
{{1,2,3,4,5},{6,7},{8},{9,10,11},{12,13,14,15,16}}输出
[1, 6, 2, 8, 7, 3, 9, 4, 12, 10, 5, 13, 11, 14, 15, 16, ]
广告
数据结构
网络
关系型数据库管理系统
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP