第二篇:矩阵的翻转JavaScript

一维数组的翻转

javascript 复制代码
// 一维矩阵翻转
// 实例: arr = [1,2,3,4,5] => [5,4,3,2,1]
let n  = readline()
let arr = readline().split(' ').map(Number)
// console.log(n,arr)
let temp = 0
for(let i = 0; i < n/2;i++){
    temp = arr[i]
    arr[i] = arr[n-i-1]
    arr[n-i-1] = temp
}
console.log(arr)

n*n矩阵的翻转

  1. 水平翻转
javascript 复制代码
// 二维矩阵水平翻转
// 实例
// 1 2 3            7 8 9
// 4 5 6      =》   4 5 6
// 7 8 9            1 2 3
let n = readline()
var arr = []
for(let i = 0; i < n;i++){
    arr[i] = readline().split(' ').map(Number)
    // for(let j = 0;j < n;j++){
    //     arr[i][j] = arr[i][j]
    // }
}
// console.log('a',arr)
for(let i = 0; i <= n/2; i++){
    for(let j = 0; j < n;j++){
        let temp = 0;
        temp = arr[i][j]
        arr[i][j] = arr[n-i-1][j]
        arr[n-i-1][j] = temp
    }
}
console.log(arr)
  1. 垂直翻转
javascript 复制代码
// 二维矩阵垂直翻转
// 实例
// 1 2 3            3 2 1
// 4 5 6      =》   6 5 4
// 7 8 9            9 8 7
let n = readline()
var arr = []
for(let i = 0; i < n;i++){
    arr[i] = readline().split(' ').map(Number)
    // for(let j = 0;j < n;j++){
    //     arr[i][j] = arr[i][j]
    // }
}
console.log('a',arr[0][0])
let temp
for(let i = 0; i < n; i++){
    for(let j = 0; j <= n/2;j++){
        console.log(temp)
        temp = arr[i][j]
        arr[i][j] = arr[i][n-j-1]
        arr[i][n-j-1] = temp
    }
}
console.log(arr)
  1. 水平垂直方向各翻转一次
javascript 复制代码
// 二维矩阵水平垂直各翻转一次
// 实例 
// 1 2 3            9 8 7
// 4 5 6      =》   6 5 4
// 7 8 9            3 2 1
let n = readline()
var arr = new Array()//定义一维数组
for(let i = 0 ; i < n ; i++){
    arr[i] = readline().split(' ').map(Number)
}
// var result = [[],[],[]]
var result = []
//reverse(arr)

// console.log(arr)
//function reverse(arr){
    for(let i = 0; i < n;i++){ 
        for(let j = 0; j <= n/2;j++){
            let temp = 0;
            temp = arr[i][j];
            arr[i][j] = arr[i][n-j-1];
            arr[i][n-j-1] = temp
        }
        result[n-i-1] = arr[i]
    }
    console.log(result)
    // document.write('<br>');
//}
相关推荐
小兵张健3 小时前
开源 playwright-pool 会话池来了
前端·javascript·github
codingWhat6 小时前
介绍一个手势识别库——AlloyFinger
前端·javascript·vue.js
Lee川6 小时前
深度拆解:基于面向对象思维的“就地编辑”组件全模块解析
javascript·架构
进击的尘埃6 小时前
Web Worker 与 OffscreenCanvas:把主线程从重活里解放出来
javascript
codingWhat6 小时前
手撸一个「能打」的 React Table 组件
前端·javascript·react.js
进击的尘埃6 小时前
用 TypeScript 的 infer 搓一个类型安全的深层路径访问工具
javascript
yuki_uix6 小时前
Object.entries:优雅处理 Object 的瑞士军刀
前端·javascript
Lee川6 小时前
JavaScript 面向对象编程全景指南:从原始字面量到原型链的终极进化
javascript·面试
Neptune111 小时前
JavaScript回归基本功之---类型判断--typeof篇
前端·javascript·面试
进击的尘埃11 小时前
微前端沙箱隔离:qiankun 和 wujie 到底在争什么
javascript