牛客NC18 顺时针旋转矩阵【中等 数学 Java/Go/PHP/C++】

2024-06-10 05:12

本文主要是介绍牛客NC18 顺时针旋转矩阵【中等 数学 Java/Go/PHP/C++】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目

在这里插入图片描述
在这里插入图片描述

题目链接:
https://www.nowcoder.com/practice/2e95333fbdd4451395066957e24909cc
https://www.lintcode.com/problem/161/

思路

在这里插入图片描述

Java代码

import java.util.*;public class Solution {/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可*** @param mat int整型二维数组* @param n int整型* @return int整型二维数组*/public int[][] rotateMatrix (int[][] mat, int n) {//1:水平翻转//rs:当前处理的第一行,re:当前处理的最后一行int rs = 0, re = n - 1;while (rs <= re) {//col:当前处理的第col列,rs行和re行的col的数进行交换for (int col = 0; col < n ; col++) {int t = mat[rs][col];mat[rs][col] = mat[re][col];mat[re][col] = t;}rs++;re--;}//2.主对角线翻转for (int i = 0; i < n ; i++) {for (int j = 0; j < i ; j++) {int t = mat[i][j];mat[i][j] = mat[j][i];mat[j][i] = t;}}return mat;}
}

Go代码

package main/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可*** @param mat int整型二维数组* @param n int整型* @return int整型二维数组*/
func rotateMatrix(mat [][]int, n int) [][]int {//1.水平翻转rs := 0re := n - 1for rs <= re {for col := 0; col < n; col++ {tmp := mat[rs][col]mat[rs][col] = mat[re][col]mat[re][col] = tmp}rs++re--}//2.对角线翻转for i := 0; i < n; i++ {for j := 0; j < i; j++ {tmp := mat[i][j]mat[i][j] = mat[j][i]mat[j][i] = tmp}}return mat
}

PHP代码

<?php/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param mat int整型二维数组 * @param n int整型 * @return int整型二维数组*/
function rotateMatrix( $mat ,  $n )
{//水平翻转$rs=0;$re = $n-1;while ($rs<=$re){for($col=0;$col<$n;$col++){$tmp = $mat[$rs][$col];$mat[$rs][$col] = $mat[$re][$col];$mat[$re][$col] = $tmp;}$rs++;$re--;}//对角线翻转for($i=0;$i<$n;$i++){for($j=0;$j<$i;$j++){$tmp = $mat[$i][$j];$mat[$i][$j] = $mat[$j][$i];$mat[$j][$i] =$tmp;}}return $mat;
}

C++ 代码

#include <bits/types/struct_tm.h>
class Solution {
public:/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param mat int整型vector<vector<>> * @param n int整型 * @return int整型vector<vector<>>*/vector<vector<int> > rotateMatrix(vector<vector<int> >& mat, int n) {//水平翻转int rs=0,re =n-1;while(rs<=re){for(int c=0;c<n;c++){int tmp = mat[rs][c];mat[rs][c] = mat[re][c];mat[re][c] =tmp;}rs++;re--;}//对角线翻转for(int i=0;i<n;i++){for(int j=0;j<i;j++){int tmp = mat[i][j];mat[i][j]=mat[j][i];mat[j][i]=tmp;}}    return mat;}
};

这篇关于牛客NC18 顺时针旋转矩阵【中等 数学 Java/Go/PHP/C++】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1047300

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

C++包装器

包装器 在 C++ 中,“包装器”通常指的是一种设计模式或编程技巧,用于封装其他代码或对象,使其更易于使用、管理或扩展。包装器的概念在编程中非常普遍,可以用于函数、类、库等多个方面。下面是几个常见的 “包装器” 类型: 1. 函数包装器 函数包装器用于封装一个或多个函数,使其接口更统一或更便于调用。例如,std::function 是一个通用的函数包装器,它可以存储任意可调用对象(函数、函数