当前位置: 首页 > news >正文

螺旋数字矩阵 - 华为OD统一考试

OD统一考试(C卷)

分值: 100分

题解: Java / Python / C++

alt

题目描述

疫情期间,小明隔离在家,百无聊赖,在纸上写数字玩。他发明了一种写法:

给出数字个数n行数m (0 < n <= 999,0 < m <= 999),从左上角的1开始,按照顺时针螺旋向内写方式,依次写出2,3…n,最终形成一个m行矩阵。

小明对这个矩阵有些要求:

  1. 每行数字的个数一样多
  2. 列的数量尽可能少
  3. 填充数字时优先填充外部
  4. 数字不够时,使用单个*号占位

输入描述

两个整数,空格隔开,依次表示n、m

输出描述

符合要求的唯一矩阵

示例1

输入:
9 4输出:
1 2 3
* * 4
9 * 5
8 7 6说明:
9个数字写成4行,最少需要3列

示例2

输入:
3 5输出:
1
2
3
*
*说明:
3个数字写5行,只有一列,数字不够用*号填充

题解

这是一个模拟题,主要考察对矩阵的遍历和填充的能力。

  1. 首先,通过输入获取数字个数n和行数m。
  2. 计算矩阵的列数cols,根据题意,最少需要的列数是(n-1) / m + 1。
  3. 初始化一个大小为m行cols列的矩阵,所有元素初始值为"*"。
  4. 使用四个变量top、bottom、left、right来表示当前矩阵的上下左右边界。
  5. 使用cur变量表示当前要填充的数字,从1开始。
  6. 进入循环,按照顺时针螺旋的方式依次填充矩阵的数字。
    • 从左到右:遍历当前行的左右范围,依次填充数字。
    • 从上到下:遍历当前列的上下范围,依次填充数字。
    • 从右到左:遍历当前行的右左范围,依次填充数字。
    • 从下到上:遍历当前列的下上范围,依次填充数字。
  7. 在每次填充后,更新相应的边界。
  8. 循环直到所有数字都填充完毕。
  9. 最后,输出填充好的矩阵。

这样,通过模拟顺时针螺旋填充的过程,就能得到符合要求的矩阵。

Java

import java.util.Arrays;
import java.util.Scanner;
import java.util.stream.Collectors;
/*** @author code5bug*/
public class Main {public static void main(String[] args) {Scanner in = new Scanner(System.in);int n = in.nextInt(), m = in.nextInt();int rows = m, cols = (n - 1) / m + 1;// grid[i][j] == 0 则认为数字不够为 *int[][] grid = new int[rows][cols];// 上下左右,四侧的边界int top = 0, bottom = rows - 1, left = 0, right = cols - 1;int cur = 1;while (cur <= n) {// 从左到右for (int i = left; i <= right && cur <= n; i++) {grid[top][i] = cur++;}if (++top > bottom) break; // 收缩范围// 从上到下for (int i = top; i <= bottom && cur <= n; i++) {grid[i][right] = cur++;}if (--right < left) break; // 收缩范围// 从右到左for (int i = right; i >= left && cur <= n; i--) {grid[bottom][i] = cur++;}if (--bottom < top) break; // 收缩范围// 从下到上for (int i = bottom; i >= top && cur <= n; i--) {grid[i][left] = cur++;}if (++left > right) break; // 收缩范围}// 输出结果Arrays.stream(grid).map(row -> Arrays.stream(row).mapToObj(num -> num == 0 ? "*" : String.valueOf(num)).collect(Collectors.joining(" "))).forEach(System.out::println);}
}

Python

n, m  = map(int, input().split())# 计算需要的列数 cols
rows, cols = m, (n - 1) // m + 1# 初始化矩阵所有值为*
grid = [['*'] * cols for _ in range(rows)]# 上下左右,四侧的边界
top, bottom, left, right = 0, rows - 1, 0, cols - 1cur = 1
while True:# 从左到右for i in range(left, right + 1):if cur <= n:grid[top][i] = curcur += 1top += 1 # 收缩范围if top > bottom: break# 从上到下for i in range(top, bottom + 1):if cur <= n:grid[i][right] = curcur += 1right -= 1 # 收缩范围if right  < left: break# 从右到左for i in range(right, left - 1, -1):if cur <= n:grid[bottom][i] = curcur += 1bottom -= 1 # 收缩范围if bottom < top: break# 从下到上for i in range(bottom, top-1, -1):if cur <= n:grid[i][left] = curcur += 1left += 1 # 收缩范围if left > right: breakfor row in grid:print(" ".join(map(str, row)))

C++

#include <iostream>
#include <vector>using namespace std;int main() {int n, m;cin >> n >> m;int rows = m, cols = (n - 1) / m + 1;// grid[i][j] == 0 则认为数字不够为 *vector<vector<int>> grid(rows, vector<int>(cols, 0));// 上下左右,四侧的边界int top = 0, bottom = rows - 1, left = 0, right = cols - 1;int cur = 1;while (cur <= n) {// 从左到右for (int i = left; i <= right && cur <= n; i++) {grid[top][i] = cur++;}if (++top > bottom) break; // 收缩范围// 从上到下for (int i = top; i <= bottom && cur <= n; i++) {grid[i][right] = cur++;}if (--right < left) break; // 收缩范围// 从右到左for (int i = right; i >= left && cur <= n; i--) {grid[bottom][i] = cur++;}if (--bottom < top) break; // 收缩范围// 从下到上for (int i = bottom; i >= top && cur <= n; i--) {grid[i][left] = cur++;}if (++left > right) break; // 收缩范围}// 输出结果for (const auto &row : grid) {for (size_t i = 0; i < row.size(); ++i) {if (row[i] == 0) {cout << "*";} else {cout << row[i];}if (i + 1 != row.size()) cout << " ";else cout << endl;}}return 0;
}

相关练习题

题号题目难易
LeetCode 5454. 螺旋矩阵中等
LeetCode LCR 146LCR 146. 螺旋遍历二维数组中等

🙏整理题解不易, 如果有帮助到您,请给点个赞 ‍❤️‍ 和收藏 ⭐,让更多的人看到。🙏🙏🙏

相关文章:

螺旋数字矩阵 - 华为OD统一考试

OD统一考试&#xff08;C卷&#xff09; 分值&#xff1a; 100分 题解&#xff1a; Java / Python / C 题目描述 疫情期间&#xff0c;小明隔离在家&#xff0c;百无聊赖&#xff0c;在纸上写数字玩。他发明了一种写法: 给出数字个数n和行数m (0 < n < 999&#xff0c;…...

更改ERPNEXT源

更改ERPNEXT源 一&#xff0c; 更改源 针对已经安装了erpnext的&#xff0c;需要更改源的情况&#xff1a; 1, 更改为官方默认源, 进入frapp-bench的目录&#xff0c; 然后执行: bench remote-reset-url frappe //重设frappe的源为官方github地址。 bench remote-reset-url…...

配置基本QinQ示例

QinQ简介 定义 QinQ&#xff08;802.1Q-in-802.1Q&#xff09;技术是一项扩展VLAN空间的技术&#xff0c;通过在802.1Q标签报文的基础上再增加一层802.1Q的Tag来达到扩展VLAN空间的功能&#xff0c;可以使私网VLAN透传公网。由于在骨干网中传递的报文有两层802.1Q Tag&#x…...

界面控件DevExpress Blazor Grid v23.2 - 支持全新的单元格编辑模式

DevExpress Blazor UI组件使用了C#为Blazor Server和Blazor WebAssembly创建高影响力的用户体验&#xff0c;这个UI自建库提供了一套全面的原生Blazor UI组件&#xff08;包括Pivot Grid、调度程序、图表、数据编辑器和报表等&#xff09;。 在这篇文章中&#xff0c;我们将介…...

深入剖析pcap中的网络异常:TTL过期攻击、ARP中毒、TCP重传与重叠碎片等

网络流量数据包捕获是网络安全领域的重要部分&#xff0c;而pcap文件则是这一过程的常见载体。为了深入解析pcap文件中潜在的可疑网络流量&#xff0c;我们需要运用强大的网络安全威胁评估与审计工具。这些工具能够帮助我们捕捉、记录、检测和诊断网络中的数据传输问题&#xf…...

网站被挂黑链怎么办

网站被挂黑链这种事情总是防不胜防&#xff0c;且不说网站本身的安全防护做的是否到位&#xff0c;但只要被盯上了就难逃厄运。即使是企业机构的网站也难逃被黑的经历&#xff0c;更何况用户苦心经营的网站&#xff0c;因此首先需要正确看待挂黑链这个现象&#xff0c;网站被挂…...

WPF 导航界面悬浮两行之间的卡片 漂亮的卡片导航界面 WPF漂亮渐变颜色 WPF漂亮导航头界面 UniformGrid漂亮展现

在现代应用程序设计中&#xff0c;一个漂亮的WPF导航界面不仅为用户提供视觉上的享受&#xff0c;更对提升用户体验、增强功能可发现性和应用整体效率起到至关重要的作用。以下是对WPF漂亮导航界面重要性的详尽介绍&#xff1a; 首先&#xff0c;引人入胜的首页界面是用户与软…...

[技术杂谈]使用VLC将视频转成一个可循环rtsp流

通过vlc播放器&#xff0c;将一个视频转成rtsp流&#xff0c;搭建一个rtsp服务器。rtsp客户端可访问这个视频的rtsp流。 1. 打开vlc播放器&#xff0c;使用的版本如下 2. 菜单&#xff1a;媒体 ---> 流 3. 添加视频文件&#xff0c;点击添加一个mp4 文件 4. 选择串流&…...

手机上连网络转接app,电脑连接手机,共用网络转接app的办法

方法一&#xff0c;&#xff08;不推荐&#xff09; 因为太简单了所以写一下 电脑安装MuMu模拟器&#xff0c;之后安装网络转接app&#xff0c;这个模拟器设置了从电脑上安装app和&#xff0c;安卓与电脑同步文件夹功能&#xff0c;实现文件共享。所以直接用就可以了。 方法二…...

k8s中的容器探针

pod的容器健康检查---探针 probe&#xff1a;k8s对容器执行的定期检查&#xff0c;诊断。 探针的三种规则 所有的探针都是针对容器不是针对pod 1、 存活探针---livenessProbe&#xff1a;探测容器是否正常运行。如果发现探测失败&#xff0c;会杀掉容器。容器会根据重启策略…...

4.6 BOUNDARY CHECKS

我们现在扩展了tile矩阵乘法内核&#xff0c;以处理具有任意宽度的矩阵。扩展必须允许内核正确处理宽度不是tile宽度倍数的矩阵。通过更改图4.14中的示例至33 M、N和P矩阵&#xff0c;图4.18创建了矩阵的宽度为3&#xff0c;不是tile宽度&#xff08;2&#xff09;的倍数。图4.…...

Java集合-LinkedList

Java集合-LinkedList 特性 public class LinkedList<E> extends AbstractSequentialList<E>implements List<E>, Deque<E>, Cloneable, java.io.Serializable1、继承于 AbstractSequentialList &#xff0c;本质上面与继承 AbstractList 没有什么区别…...

2023年阿里云云栖大会:前沿技术发布与未来展望

在2023年的阿里云云栖大会上&#xff0c;我见证了云计算和人工智能领域的又一历史性时刻。这次大会不仅是对未来科技趋势的一次深入探索&#xff0c;更是阿里云技术实力和创新能力的集中展示。 首先&#xff0c;千亿级参数规模的大模型通义千问2.0的发布&#xff0c;无疑将人工…...

houdini microscope

【英文原版-无字幕】Wavelets: a mathematical microscope 小波变换最好的入门教程了吧&#xff01;_哔哩哔哩_bilibili 只涉及模拟&#xff0c;不模拟具体对错...

Linux_CentOS_7.9配置时区及NTPdate同步之简易记录

前言&#xff1a;ntpdate命令来自英文词组”NTPdate“的拼写&#xff0c;其功能是用于设置日期和时间。ntpdate命令能够基于NTP协议设置Linux系统的本地日期和时间&#xff0c;利用NTP服务的时钟过滤器来选择最优方案&#xff0c;大大提高了可靠性和精度&#xff0c;让系统时间…...

十九:爬虫最终篇-平安银行商城实战

平安银行商场实战 需求 获取该商城商品信息 目标网址 https://m.yqb.com/bank/product-item-50301196.html?mcId1583912328849970&loginModepab&historyy&sceneModem&traceid30187_4dXJVel1iop详细步骤 1、寻找数据接口 2、对比payload寻找可疑参数 3、多…...

解决vcruntime140_1.dll无法继续执行代码的方法,一键修复dll文件丢失问题。

vcruntime140_1.dll是Windows操作系统中的一个重要的动态链接库文件&#xff0c;它与Microsoft Visual C Redistributable相关联。电脑出现关于vcruntime140_1.dll无法继续执行代码的错误弹窗是就意味着这个文件在电脑中被破坏导致丢失了&#xff0c;这将会影响一些程序不能正常…...

Elasticsearch:结合 ELSER 和 BM25 文本查询的相关搜索

Elastic Learned Spare EncodeR (ELSER) 允许你执行语义搜索以获得更相关的搜索结果。 然而&#xff0c;有时&#xff0c;将语义搜索结果与常规关键字搜索结果相结合以获得最佳结果会更有用。 问题是&#xff0c;如何结合文本和语义搜索结果&#xff1f; 首先&#xff0c;让我…...

海外社媒运营为什么需要选择优质IP代理?

跨境电商卖家尤其需要关注海外社媒运营&#xff0c;想要更好地运营Instagram、Facebook、TikTok 或 Twitter等&#xff0c;挖掘社媒潜力需要采取战略方法&#xff0c;而社交媒体IP代理在这一活动中发挥着至关重要的作用&#xff0c;下面为你详细介绍。 一、社交媒体代理IP及其运…...

Java中的性能优化:深入剖析常见优化技巧

引言 在现代软件开发中&#xff0c;性能优化是一个至关重要的话题。Java作为一门强大而广泛使用的编程语言&#xff0c;也需要开发者关注和优化性能&#xff0c;以确保应用程序能够在各种场景下高效运行。本文将深入剖析Java中的一些常见性能优化技巧&#xff0c;为开发者提供…...

智能排障:借助快马AI构建Vivado安装问题自动诊断与修复助手

作为一名FPGA开发者&#xff0c;Vivado安装过程中的各种报错简直是家常便饭。每次遇到新问题都要花大量时间搜索解决方案&#xff0c;效率实在太低。最近尝试用InsCode(快马)平台的AI能力搭建了一个智能诊断工具&#xff0c;效果出乎意料的好&#xff0c;分享下具体实现思路。 …...

3000+开源蓝图:革新性一站式戴森球计划工厂解决方案

3000开源蓝图&#xff1a;革新性一站式戴森球计划工厂解决方案 【免费下载链接】FactoryBluePrints 游戏戴森球计划的**工厂**蓝图仓库 项目地址: https://gitcode.com/GitHub_Trending/fa/FactoryBluePrints 面对戴森球计划中错综复杂的生产线布局&#xff0c;你是否曾…...

Python实现中国象棋AI对战【完整代码+算法解析】

1. 中国象棋AI对战系统设计思路 中国象棋AI对战系统的核心在于将传统规则转化为计算机可执行的逻辑&#xff0c;同时赋予AI"思考"能力。我最初尝试开发这个项目时&#xff0c;发现最大的挑战不是代码实现&#xff0c;而是如何让AI理解象棋的策略本质。经过多次迭代&a…...

ELK+Metricbeat搭建服务器监控看板:CPU/内存/磁盘全搞定

ELKMetricbeat实战&#xff1a;打造企业级服务器监控看板 当服务器集群规模超过50台时&#xff0c;凌晨三点被电话叫醒处理性能问题的运维人员&#xff0c;最需要的不是咖啡&#xff0c;而是一套能实时呈现CPU、内存、磁盘等关键指标的智能监控系统。本文将手把手带您用ELK Sta…...

IDEA里JProfiler插件怎么配?手把手教你分析Spring Boot内存泄漏(附OOM复现技巧)

IDEA集成JProfiler实战&#xff1a;Spring Boot内存泄漏分析与OOM复现技巧 作为Java开发者&#xff0c;你是否经历过这样的场景&#xff1a;线上服务突然崩溃&#xff0c;日志里赫然写着java.lang.OutOfMemoryError&#xff0c;而你却无从下手&#xff1f;本文将带你深入Intell…...

从1997年的论文到2024年的实践:聊聊LEO卫星网络里那个‘过时’但依然有用的DT-DVTR算法

从1997年的论文到2024年的实践&#xff1a;LEO卫星网络里那个‘过时’但依然有用的DT-DVTR算法 在星链&#xff08;Starlink&#xff09;和OneWeb掀起全球卫星互联网热潮的今天&#xff0c;回望1997年Markus Werner那篇开创性的论文&#xff0c;会惊讶地发现&#xff1a;现代低…...

使用Pi0具身智能开发教育机器人的完整指南

使用Pi0具身智能开发教育机器人的完整指南 1. 引言 教育领域正在经历一场智能化变革&#xff0c;传统的教学模式已经难以满足个性化学习的需求。想象一下&#xff0c;一个能够理解学生情绪、提供个性化辅导、并且24小时在线的教育助手——这就是教育机器人带来的可能性。 Pi…...

告别Postman!用VSCode REST Client插件管理你的HTTP请求(附环境变量实战)

告别Postman&#xff01;用VSCode REST Client插件管理你的HTTP请求&#xff08;附环境变量实战&#xff09; 在开发者的日常工作中&#xff0c;API调试是不可或缺的一环。传统上&#xff0c;Postman等独立工具占据了主导地位&#xff0c;但随着开发工具链的整合趋势&#xff0…...

LaTeX科技论文写作:如何优雅地呈现SenseVoice-Small模型实验数据

LaTeX科技论文写作&#xff1a;如何优雅地呈现SenseVoice-Small模型实验数据 写论文&#xff0c;尤其是技术论文&#xff0c;最头疼的往往不是实验本身&#xff0c;而是如何把那些复杂的模型结构、密密麻麻的数据和曲线图&#xff0c;清晰又专业地呈现在纸上。你辛辛苦苦跑出来…...

iStoreOS软路由结合Cpolar内网穿透:打造稳定高效的居家远程办公网络

1. 为什么你需要iStoreOS软路由Cpolar组合&#xff1f; 最近两年远程办公越来越普遍&#xff0c;但很多朋友都遇到过这样的困扰&#xff1a;公司电脑里的文件急着要用&#xff0c;跑回办公室又太麻烦&#xff1b;出差在外需要调取内网资料&#xff0c;VPN连接却卡成幻灯片。我自…...