第二篇:矩阵的翻转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>');
//}
相关推荐
霸王蟹33 分钟前
带你手写React中的useReducer函数。(底层实现)
前端·javascript·笔记·学习·react.js·typescript·前端框架
托尼沙滩裤38 分钟前
【Vue3】实现屏幕共享惊艳亮相
前端·javascript·vue.js
啃火龙果的兔子44 分钟前
前端八股文-vue篇
前端·javascript·vue.js
Mintopia1 小时前
计算机图形学环境贴图(Environment Mapping)教学指南
前端·javascript·计算机图形学
shenyan~1 小时前
关于 WASM: WASM + JS 混合逆向流程
开发语言·javascript·wasm
Mintopia1 小时前
Three.js 高级纹理(Advanced Textures):超越基础,打造沉浸式 3D 世界
前端·javascript·three.js
玄玄子1 小时前
JS Promise
前端·javascript·程序员
Raink老师1 小时前
7. TypeScript接口
javascript·typescript
Thanks_ks1 小时前
探索现代 Web 开发:从 HTML5 到 Vue.js 的全栈之旅
javascript·vue.js·css3·html5·前端开发·web 开发·全栈实战
GIS之路2 小时前
OpenLayers 获取地图状态
前端·javascript·html