蓝桥杯vip试题 基础练习 回形取数(java实现)

2024-03-19 02:38

本文主要是介绍蓝桥杯vip试题 基础练习 回形取数(java实现),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

资源限制

时间限制:1.0s 内存限制:512.0MB

问题描述

  回形取数就是沿矩阵的边取数,若当前方向上无数可取或已经取过,则左转90度。一开始位于矩阵左上角,方向向下。

输入格式

  输入第一行是两个不超过200的正整数m, n,表示矩阵的行和列。接下来m行每行n个整数,表示这个矩阵。

输出格式

  输出只有一行,共mn个数,为输入矩阵回形取数得到的结果。数之间用一个空格分隔,行末不要有多余的空格。

样例输入

3 3
1 2 3
4 5 6
7 8 9

样例输出

1 4 7 8 9 6 3 2 5

样例输入

3 2
1 2
3 4
5 6

样例输出

1 3 5 6 4 2

随便讲讲:虽然这题有很多解答,但是我发现java的没有很多说得很细致的,我就小白式地总结一下。这题要通过转圈圈遍历所有数,每转一次的四个点很重要。因为每转完一圈范围会缩小,所以转完一圈这四个顶点的值也要相应调整,然后调整新的起点,在这里就是x和y。每次转圈,都是经过四条边,每条边的“前进动作”也不一样,所以每条边都用一个while循环操作,分离出来一直重复这四个循环就好了。这题还有个关键地方是结束条件。当左边顶点越过右边顶点,就表示已经遍历完。但是按照我这种算法,当while循环后,如果是奇数阶方阵(m=n&m为奇数),最中间那个数不会被遍历到。但是这恰恰为我提供了便利,因为我还需要考虑最后一个输出不能带空格的问题。所以在循环中我用count记录已输出了多少个数,如果已经已经到最后一个了,就需要跳出循环单独处理。但是如果是奇数阶方阵,它是根据while循环中的条件跳出的,因为它始终只能输出总数-1个。

import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner in = new Scanner(System.in);int m = in.nextInt();int n = in.nextInt();int[][] matrix = new int[m][n];for (int i = 0; i < m; i++) for (int j = 0; j < n; j++) matrix[i][j] = in.nextInt();int leftUpRow = 0;int leftUpCol = 0;int rightDownRow = m - 1;int rightDownCol = n - 1;int count = 0, x = 0, y = 0;while (leftUpRow <= rightDownRow && leftUpCol <= rightDownCol) {x = leftUpRow;y = leftUpCol;while (x < rightDownRow) {if (++count == m * n) break;System.out.print(matrix[x][y] + " ");x++;}rightDownRow--;while (y < rightDownCol) {if (++count == m * n) break;System.out.print(matrix[x][y] + " ");y++;}rightDownCol--;while (x > leftUpRow) {if (++count == m * n) break;System.out.print(matrix[x][y] + " ");x--;}leftUpRow++;while (y > leftUpCol) {if (++count == m * n) break;System.out.print(matrix[x][y] + " ");y--;}leftUpCol++;}if (count == m * n) {System.out.print(matrix[x][y]);} else {System.out.print(matrix[m / 2][n / 2]);}in.close();}}

这篇关于蓝桥杯vip试题 基础练习 回形取数(java实现)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringBoot通过main方法启动web项目实践

《SpringBoot通过main方法启动web项目实践》SpringBoot通过SpringApplication.run()启动Web项目,自动推断应用类型,加载初始化器与监听器,配置Spring... 目录1. 启动入口:SpringApplication.run()2. SpringApplicat

Redis实现分布式锁全过程

《Redis实现分布式锁全过程》文章介绍Redis实现分布式锁的方法,包括使用SETNX和EXPIRE命令确保互斥性与防死锁,Redisson客户端提供的便捷接口,以及Redlock算法通过多节点共识... 目录Redis实现分布式锁1. 分布式锁的基本原理2. 使用 Redis 实现分布式锁2.1 获取锁

从基础到进阶详解Python条件判断的实用指南

《从基础到进阶详解Python条件判断的实用指南》本文将通过15个实战案例,带你大家掌握条件判断的核心技巧,并从基础语法到高级应用一网打尽,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录​引言:条件判断为何如此重要一、基础语法:三行代码构建决策系统二、多条件分支:elif的魔法三、

Python WebSockets 库从基础到实战使用举例

《PythonWebSockets库从基础到实战使用举例》WebSocket是一种全双工、持久化的网络通信协议,适用于需要低延迟的应用,如实时聊天、股票行情推送、在线协作、多人游戏等,本文给大家介... 目录1. 引言2. 为什么使用 WebSocket?3. 安装 WebSockets 库4. 使用 We

Java利用@SneakyThrows注解提升异常处理效率详解

《Java利用@SneakyThrows注解提升异常处理效率详解》这篇文章将深度剖析@SneakyThrows的原理,用法,适用场景以及隐藏的陷阱,看看它如何让Java异常处理效率飙升50%,感兴趣的... 目录前言一、检查型异常的“诅咒”:为什么Java开发者讨厌它1.1 检查型异常的痛点1.2 为什么说

Linux实现查看某一端口是否开放

《Linux实现查看某一端口是否开放》文章介绍了三种检查端口6379是否开放的方法:通过lsof查看进程占用,用netstat区分TCP/UDP监听状态,以及用telnet测试远程连接可达性... 目录1、使用lsof 命令来查看端口是否开放2、使用netstat 命令来查看端口是否开放3、使用telnet

基于Java开发一个极简版敏感词检测工具

《基于Java开发一个极简版敏感词检测工具》这篇文章主要为大家详细介绍了如何基于Java开发一个极简版敏感词检测工具,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录你是否还在为敏感词检测头疼一、极简版Java敏感词检测工具的3大核心优势1.1 优势1:DFA算法驱动,效率提升10

Java使用正则提取字符串中的内容的详细步骤

《Java使用正则提取字符串中的内容的详细步骤》:本文主要介绍Java中使用正则表达式提取字符串内容的方法,通过Pattern和Matcher类实现,涵盖编译正则、查找匹配、分组捕获、数字与邮箱提... 目录1. 基础流程2. 关键方法说明3. 常见场景示例场景1:提取所有数字场景2:提取邮箱地址4. 高级

使用SpringBoot+InfluxDB实现高效数据存储与查询

《使用SpringBoot+InfluxDB实现高效数据存储与查询》InfluxDB是一个开源的时间序列数据库,特别适合处理带有时间戳的监控数据、指标数据等,下面详细介绍如何在SpringBoot项目... 目录1、项目介绍2、 InfluxDB 介绍3、Spring Boot 配置 InfluxDB4、I

基于Java和FFmpeg实现视频压缩和剪辑功能

《基于Java和FFmpeg实现视频压缩和剪辑功能》在视频处理开发中,压缩和剪辑是常见的需求,本文将介绍如何使用Java结合FFmpeg实现视频压缩和剪辑功能,同时去除数据库操作,仅专注于视频处理,需... 目录引言1. 环境准备1.1 项目依赖1.2 安装 FFmpeg2. 视频压缩功能实现2.1 主要功