牛客题解 | 打印回形数

news/2025/3/5 12:08:42/文章来源:https://www.cnblogs.com/wc529065/p/18752376

题目

题目链接

解题思路

这是一个模拟题,需要按照顺时针方向填充矩阵。主要思路是:

  1. 创建指定大小的矩阵
  2. 使用方向数组控制移动
  3. 遇到边界或已填充的位置时改变方向

关键点

  1. 使用方向数组表示四个方向的移动
  2. 判断下一步是否可以移动(是否越界或已填充)
  3. 按照右->下->左->上的顺序循环移动

代码

#include <iostream>
#include <vector>
#include <iomanip>
using namespace std;class Solution {
private:// 四个方向:右、下、左、上const int dx[4] = {0, 1, 0, -1};const int dy[4] = {1, 0, -1, 0};public:void printSpiralMatrix(int width, int height) {vector<vector<int>> matrix(height, vector<int>(width, -1));int x = 0, y = 0;  // 当前位置int dir = 0;       // 当前方向int num = 0;       // 当前数字// 填充矩阵while (true) {matrix[x][y] = num;// 尝试移动到下一个位置int nx = x + dx[dir];int ny = y + dy[dir];// 如果下一个位置不可用,改变方向if (nx < 0 || nx >= height || ny < 0 || ny >= width || matrix[nx][ny] != -1) {dir = (dir + 1) % 4;nx = x + dx[dir];ny = y + dy[dir];// 如果改变方向后仍然不可用,说明填充完成if (nx < 0 || nx >= height || ny < 0 || ny >= width || matrix[nx][ny] != -1) {break;}num++;  // 改变方向时数字加1}x = nx;y = ny;}// 打印矩阵for (int i = 0; i < height; i++) {for (int j = 0; j < width; j++) {cout << matrix[i][j];}cout << endl;}}
};int main() {int width, height;cin >> width >> height;Solution solution;solution.printSpiralMatrix(width, height);return 0;
}
import java.util.Scanner;public class Main {static class Solution {// 四个方向:右、下、左、上private final int[] dx = {0, 1, 0, -1};private final int[] dy = {1, 0, -1, 0};public void printSpiralMatrix(int width, int height) {int[][] matrix = new int[height][width];// 初始化矩阵为-1for (int i = 0; i < height; i++) {for (int j = 0; j < width; j++) {matrix[i][j] = -1;}}int x = 0, y = 0;  // 当前位置int dir = 0;       // 当前方向int num = 0;       // 当前数字// 填充矩阵while (true) {matrix[x][y] = num;// 尝试移动到下一个位置int nx = x + dx[dir];int ny = y + dy[dir];// 如果下一个位置不可用,改变方向if (nx < 0 || nx >= height || ny < 0 || ny >= width || matrix[nx][ny] != -1) {dir = (dir + 1) % 4;nx = x + dx[dir];ny = y + dy[dir];// 如果改变方向后仍然不可用,说明填充完成if (nx < 0 || nx >= height || ny < 0 || ny >= width || matrix[nx][ny] != -1) {break;}num++;  // 改变方向时数字加1}x = nx;y = ny;}// 打印矩阵for (int i = 0; i < height; i++) {for (int j = 0; j < width; j++) {System.out.print(matrix[i][j]);}System.out.println();}}}public static void main(String[] args) {Scanner sc = new Scanner(System.in);int width = sc.nextInt();int height = sc.nextInt();Solution solution = new Solution();solution.printSpiralMatrix(width, height);sc.close();}
}
class Solution:def print_spiral_matrix(self, width: int, height: int) -> None:# 四个方向:右、下、左、上dx = [0, 1, 0, -1]dy = [1, 0, -1, 0]# 创建并初始化矩阵matrix = [[-1] * width for _ in range(height)]x, y = 0, 0  # 当前位置dir = 0      # 当前方向num = 0      # 当前数字# 填充矩阵while True:matrix[x][y] = num# 尝试移动到下一个位置nx = x + dx[dir]ny = y + dy[dir]# 如果下一个位置不可用,改变方向if (nx < 0 or nx >= height or ny < 0 or ny >= width or matrix[nx][ny] != -1):dir = (dir + 1) % 4nx = x + dx[dir]ny = y + dy[dir]# 如果改变方向后仍然不可用,说明填充完成if (nx < 0 or nx >= height or ny < 0 or ny >= width or matrix[nx][ny] != -1):breaknum += 1  # 改变方向时数字加1x, y = nx, ny# 打印矩阵for row in matrix:print(''.join(map(str, row)))def main():width, height = map(int, input().split())solution = Solution()solution.print_spiral_matrix(width, height)if __name__ == "__main__":main()

算法及复杂度

  • 算法:模拟
  • 时间复杂度:\(\mathcal{O}(width * height)\),需要填充整个矩阵
  • 空间复杂度:\(\mathcal{O}(width * height)\),需要存储矩阵

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/893955.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

为什么重新object的finalize方法后,PhantomReference失效了

未重写Object的finalize方法public static class MyObject {}使用 PhantomReference 来监听引用是否被回收ReferenceQueue<Object> queue = new ReferenceQueue<>();MyObject object = new MyObject();PhantomReference<MyObject> phantomReference = new Ph…

牛客题解 | 平方串

牛客题库题解题目 题目链接 题解 题目难度:中等 知识点:LCS(最长公共子序列问题),动态规划 分析: 本题实际是要找出s的最长子序列,看到这个问题就应该想到利用动态规划去解决。一般是找s1、s2两个字符串中的最长子序列,那么该题中就可以遍历s,以每个字符位置作为分割点…

车身域控制器BDCU

集成化是整车降本最重要的手段,域控和线束的深度融合是提升整车集成度的关键。车身域控制器作为汽车域控制器之一,在功能集成、系统优化和技术创新方面取得了显著进展。经纬恒润自主研发的车身域控制器(BDCU),能够兼容传统BCM功能,同时集成空调算法、门控逻辑、胎压监控等…

随记-NGNIX关于反向代理8080 和 8081

​ 在\conf\nginx.conf中有一段代码这里解释是: 在这个 Nginx 配置中,8080 和 8081 是两个不同的端口,分别用于不同的用途。它们的关系如下:8080 端口 作用: Nginx 监听 8080 端口,作为前端请求的入口。 功能: 处理静态资源请求(如前端页面)。 将 /api 开头的请求转发到…

RLChina2024 | 汪军 LLM and AI Agents: A Roadmap and Vision towards AGI

本文记录此次报告的key point(个人向) llm时代的几点difficulityInference-time computation scallingOpenAI o1 利用RL来显式整合inference期间推理的step(inference-time computation) (从predicte next-token范式到RL解决问题范式)predict next token是监督学习,受限于…

若依开发微信小程序遇到的问题一

如上所述,该错误是由于Spring在创建familyMemberController时,无法满足familyMemberService的依赖注入。进一步追踪发现,wechatServiceImpl中的wechat.appId配置项未正确配置,导致依赖注入失败。 分析原因可能是配置文件缺失或错误:wechat.appId在配置文件中未定义或拼写错…

AI工具链接汇总

1、chatgpt4 https://www.chatgp4.com/gpt功能应用场景:智能文案生成:GPT网页版智能平台具备强大的自然语言处理能力,能够根据用户输入的关键词或提示,生成高质量的文章、广告文案、营销邮件等。无论是文章创作、内容编辑,还是社交媒体上的推文撰写,都能高效完成,极大地…

linux另类实现matlab编辑器的vim模式

使用matlab编程练习中,发现matlab的自带的编辑器也不错,主要是分节运行非常方便,但是没有vim模式有点难受。经过摸索,变相实现了matlab中的编辑器的vim模式。安装好linux下matlab 2024a,其他版本也无所谓,安装好vim,我的是最新版本。左边显示器垂直放置,右边显示器水平…

在Unity转微信小游戏下,如何用Worker实现多线程

1)在Unity转微信小游戏下,如何用Worker实现多线程2)Unity的jslib库和微信小游戏的game.js如何互相调用函数或者通信3)如何在Unity中实现资源的深度复制这是第422篇UWA技术知识分享的推送,精选了UWA社区的热门话题,涵盖了UWA问答、社区帖子等技术知识点,助力大家更全面地…

YASKAWA喷涂机器人维修的常见问题

一、安川机器人示教器维修步骤详解 - 检查电源供应:确保电源供应正常,检查电源模块是否有短路或其他损坏。 - 检查连接:检查示教器与其他组件的连接是否牢固,包括电缆、插头等。 - 检查电路板:检查示教器电路板上的电子元件是否有明显的损坏,如烧焦、膨胀…

面试官:谈谈你对线程池拒绝策略的理解?

线程池的拒绝策略是指,当线程池无法承载更多任务时执行的行为。也就是当线程池的核心线程数、最大线程、任务队列都满的情况下,又来了新的任务时,线程池执行的行为被称之为线程池的拒绝策略。 线程池的执行流程如下:1.内置拒绝策略 在 Java 中,线程池内置了以下四种拒绝策…