यहाँ कई अच्छे जवाब! मैंने उन्हें एक उत्तर में समेकित किया और एक अधिक आधुनिक वाक्य रचना के लिए कुछ कोड अपडेट किए:
वन-लाइनर्स फवाद गफूर और óscar Gómez Alcañiz से प्रेरित हैं
function transpose(matrix) {
return matrix[0].map((col, i) => matrix.map(row => row[i]));
}
function transpose(matrix) {
return matrix[0].map((col, c) => matrix.map((row, r) => matrix[r][c]));
}
एंड्रयू टाटोमायर द्वारा कम के साथ कार्यात्मक दृष्टिकोण शैली
function transpose(matrix) {
return matrix.reduce((prev, next) => next.map((item, i) =>
(prev[i] || []).concat(next[i])
), []);
}
लॉडश / अंडरस्कोर मार्सेल द्वारा
function tranpose(matrix) {
return _.zip(...matrix);
}
// Without spread operator.
function transpose(matrix) {
return _.zip.apply(_, [[1,2,3], [1,2,3], [1,2,3]])
}
वेनिला दृष्टिकोण
function transpose(matrix) {
const rows = matrix.length, cols = matrix[0].length;
const grid = [];
for (let j = 0; j < cols; j++) {
grid[j] = Array(rows);
}
for (let i = 0; i < rows; i++) {
for (let j = 0; j < cols; j++) {
grid[j][i] = matrix[i][j];
}
}
return grid;
}
वेनिला इन-प्लेस ES6 दृष्टिकोण इमानुएल सरिंगन से प्रेरित है
function transpose(matrix) {
for (var i = 0; i < matrix.length; i++) {
for (var j = 0; j < i; j++) {
const temp = matrix[i][j];
matrix[i][j] = matrix[j][i];
matrix[j][i] = temp;
}
}
}
// Using destructing
function transpose(matrix) {
for (var i = 0; i < matrix.length; i++) {
for (var j = 0; j < i; j++) {
[matrix[i][j], matrix[j][i]] = [matrix[j][i], matrix[i][j]];
}
}
}
arrayLength
पैरामीटर वास्तव में उपयोग किया जाता है? यह सुनिश्चित करने के लिए कि आप सरणी में तत्वों की एक निश्चित संख्या से आगे नहीं जाते हैं?