第二篇:矩阵的翻转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>');
//}
相关推荐
yuezhilangniao2 小时前
AI智能体全栈开发工程化规范 备忘 ~ fastAPI+Next.js
javascript·人工智能·fastapi
铅笔侠_小龙虾3 小时前
Flutter Demo
开发语言·javascript·flutter
2501_944525544 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 账户详情页面
android·java·开发语言·前端·javascript·flutter
wangdaoyin20104 小时前
若依vue2前后端分离集成flowable
开发语言·前端·javascript
天天进步20154 小时前
AI Agent 与流式处理:Motia 在生成式 AI 时代的后端范式
javascript
心柠4 小时前
vue3相关知识总结
前端·javascript·vue.js
常年游走在bug的边缘5 小时前
掌握JavaScript作用域:从函数作用域到块级作用域的演进与实践
开发语言·前端·javascript
极致♀雨6 小时前
vue2+elementUI table表格勾选行冻结/置顶
前端·javascript·vue.js·elementui
林shir6 小时前
3-15-前端Web实战(Vue工程化+ElementPlus)
前端·javascript·vue.js
换日线°7 小时前
前端炫酷展开效果
前端·javascript·vue