मान लीजिए कि हमारे पास nums नामक सूचियों की एक सूची है, हमें अंकों के सभी तत्वों को विकर्ण क्रम में दिखाना होगा।
तो, अगर इनपुट पसंद है
तो आउटपुट [1,6,2,8,7,3,9,4,12,10,5,13,11,14,15,16]
होगाइसे हल करने के लिए, हम इन चरणों का पालन करेंगे -
-
एक सरणी रिट परिभाषित करें
-
एक 2डी सरणी को परिभाषित करें v
-
इनिशियलाइज़ i :=0 के लिए, जब i <अंकों का आकार, अपडेट करें (i से 1 बढ़ाएँ), करें -
-
इनिशियलाइज़ j :=0 के लिए, जब j <अंकों का आकार [i], अपडेट करें (j को 1 से बढ़ाएँ), करें -
-
v के अंत में { nums[i, j], i, j } डालें
-
-
-
सरणी को क्रमबद्ध करें v
-
v, do,
. में प्रत्येक के लिए-
इसे [0] रिट के अंत में डालें
-
-
वापसी रिट
उदाहरण
आइए बेहतर समझ पाने के लिए निम्नलिखित कार्यान्वयन देखें -
#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, ]