P5731 【深基5.习6】蛇形方阵

题目描述

给出一个不大于 9 9 9 的正整数 n n n,输出 n × n n\times n n×n
的蛇形方阵。

从左上角填上 1 1 1 开始,顺时针方向依次填入数字,如同样例所示。注意每个数字有都会占用 3 3 3 个字符,前面使用空格补齐。

输入格式

输入一个正整数 n n n,含义如题所述。

输出格式

输出符合题目要求的蛇形矩阵。

样例 #1

样例输入 #1

4

样例输出 #1

  1  2  3  412 13 14  511 16 15  610  9  8  7

提示

数据保证, 1 ≤ n ≤ 9 1 \leq n \leq 9 1n9

1.题目分析

需要总结数学规律,二维数组就能解决,难在数组的遍历。
题意很简单:一个N乘N的矩阵,从矩阵第一个元素开始,顺时针按顺序打印,从边界到中心,从小到大,直到输出N平方结束。

这里说几个坑:
第一,总结一般规律是要考虑,由于边界缩小带来的条件变化。
第二,就是判断元素向内旋转的时机,这里就简称为拐点,拐点可能不止一个或者两个,不能简单的静态判断,需要使用修改边界之后的边长计算新的拐点。
最后,打印时每个字符占三位:%3d.

2.题目思路

创建一个二维数组用于存储结果,定义一个自然数k作为元素值,初始化为1,
定义x,y记录k-1(这里K表示当前值,K-1表示上一个值)的坐标,
将二维数组的第一个元素初始化为1,
每层打印之后,降维到下一层,这里设置一个自增因子:用于边界判断,
计算第一次边界拐点值:例如:4 * 4的矩阵拐点就为:12,NN就为:(4N-4),

写一个while循环:
1.首先进行拐点判断:计算每一层的拐点值,如果当前的K值等于拐点时,在保证大于零的情况下,边界减二(上下左右边长减一,就是总边长减二),拐点值累加新的边界计算之后的拐点值,自增因子加一。
2.对数字存放的位置进行规律总结判断:
四个判断:

  • 条件一: 若(K-1)在第1行且不在最后一列,则将K填在(K-1)的右一列
  • 条件二 : 若(K-1)在最后一列且不在最后一行,则将K填在(K-1)的正下方
  • 条件三 : 若(K-1)在最后一行且不在第一列,则将K填在(K-1)的左一列
  • 条件四 : 若(K-1)在第一列且不在第一行,则将K填在(K-1)的正上方

满足上述条件则依次存放进二维数组,值得注意的是,需要将每次元素的坐标值手动更新,以便下一次元素存放时判断。
值得一提的是,如果有多层嵌套的情况,这里用自增因子缩小边界值,判断的条件不用改变。
3.判断循环跳出的条件为:大于N的平方

到此,循环结束。
最后,循环遍历二维数组,打印规定的格式即可。

3.代码实现

#include <stdio.h>int main() {int n;//创建一个二维数组int arr[9][9] = {0};scanf("%d", &n);//定义一个自然数kint k = 1;//定义x,y记录k-1的坐标int x, y;x = 0;y = 0;//确定1的位置arr[x][y] = k;//每层打印之后,降维到下一层,这里设置一个自增因子:用于边界判断int cnt = 0;//记录n的值int p = n;//计算第一次边界拐点值int sum = 4 * n - 4;//当k大于n*n时,循环结束while (k < n * n) {//计算每一层的拐点值if (sum == k) {//上下左右边长减一,就是总边长减二,保证边长大于零if (p - 2 > 0) {p -= 2;}//拐点值随着边界缩小而递加sum = sum + (4 * p - 4);//自增因子加一cnt++;}//条件一: 若(K-1)在第1行且不在最后一列,则将K填在(K-1)的右一列//如果有多层嵌套的情况,这里用自增因子缩小边界值,判断的条件不用改变if (x == 0 + cnt && y != n - 1 - cnt) {y += 1;k++;arr[x][y] = k;}//条件二 : 若(K-1)在最后一列且不在最后一行,则将K填在(K-1)的正下方//如果有多层嵌套的情况,这里用自增因子缩小边界值,判断的条件不用改变if (y == n - 1 - cnt && x != n - 1 - cnt) {k++;x++;arr[x][y] = k;}//条件三 : 若(K-1)在最后一行且不在第一列,则将K填在(K-1)的左一列//如果有多层嵌套的情况,这里用自增因子缩小边界值,判断的条件不用改变if (x == n - 1 - cnt && y != 0 + cnt) {k++;y--;arr[x][y] = k;}//条件四 : 若(K-1)在第一列且不在第一行,则将K填在(K-1)的正上方//如果有多层嵌套的情况,这里用自增因子缩小边界值,判断的条件不用改变if (y == 0 + cnt && x != 0 + cnt) {k++;//判断K值是否超出范围if (k > n * n) {break;}x--;arr[x][y] = k;}}//遍历数组,查看结果for (int i = 0; i < n; ++i) {for (int j = 0; j < n; ++j) {//%3d占三位printf("%3d", arr[i][j]);}printf("\n");}return 0;
}

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

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

相关文章

【LeetCode】统计N以内的素数(质数)

题述 给定一个值n&#xff0c;统计2~n以内&#xff0c;素数的个数 说明&#xff1a; 素数&#xff0c;即质数。除0、1以外&#xff0c;只能被1和自身整除的自然数&#xff0c;即为素数。 例&#xff1a; 输入&#xff1a;100 输出&#xff1a;25 解决办法 方式一&#xff1a…

删除注释(力扣)

删除注释 题目 给一个 C 程序&#xff0c;删除程序中的注释。这个程序source是一个数组&#xff0c;其中source[i]表示第 i 行源码。 这表示每行源码由 ‘\n’ 分隔。 在 C 中有两种注释风格&#xff0c;行内注释和块注释。 字符串// 表示行注释&#xff0c;表示//和其右侧…

冒泡排序【Java算法】

文章目录 1. 概念2. 思路3. 代码实现 1. 概念 比较前后相邻的两个数据&#xff0c;如果前面数据大于后面的数据&#xff0c;就将这两个数据互换。这样对数组的第0个数据到第 N - 1 个数据进行一次遍历后&#xff0c;最大的一个数据就 “沉” 到数组的第 N - 1 个位置。 N N - …

知识区博主转型——兼做知识区和改造区博主!!!!!

想脱单的进来&#xff0c;一起交流如何能脱单&#xff01;&#xff01;&#xff01; 为什么——我太羡慕有对象的人了哭死&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; 你是不是很羡慕别人怎么都有女朋友 别人家的女朋友怎么都那么好&#xff…

FPGA学习—通过数码管实现电子秒表模拟

文章目录 一、数码管简介二、项目分析三、项目源码及分析四、实现效果五、总结 一、数码管简介 请参阅博主以前写过的一篇电子时钟模拟&#xff0c;在此不再赘述。 https://blog.csdn.net/qq_54347584/article/details/130402287 二、项目分析 项目说明&#xff1a;本次项目…

RISCV 5 RISC-V调用规则

RISCV 5 RISC-V调用规则 1 Register Convention1.1 Integer Register Convention1.2 Floating-point Register Convention 2. Procedure Calling Convention2.1 Integer Calling Convention2.2 Hardware Floating-point Calling Convention2.3 ILP32E Calling Convention2.4 Na…

大数据课程F4——HIve的其他操作

文章作者邮箱&#xff1a;yugongshiyesina.cn 地址&#xff1a;广东惠州 ▲ 本章节目的 ⚪ 掌握HIve的join&#xff1b; ⚪ 掌握HIve的查询和排序 ⚪ 掌握HIve的beeline ⚪ 掌握HIve的文件格式 ⚪ 掌握HIve的基本架构 ⚪ 掌握HIve的优化&#xff1b; 一、jo…

想了解好用的翻译pdf的软件吗?

在全球化的时代背景下&#xff0c;跨国贸易越来越普遍&#xff0c;跨语言沟通也越来越频繁。小黄是一家跨国公司的员工&#xff0c;他梦想能在全球各地拓展自己的业务&#xff0c;奈何遇到了一个巨大的挑战&#xff1a;跨语言沟通。在这其中&#xff0c;pdf文件是他经常接收到的…

java基础总结

1.java静态变量&#xff0c;代码块&#xff0c;和静态方法执行顺序是什么 代码块分三种&#xff1a;static静态代码块&#xff0c;构造代码块&#xff0c;普通代码块 代码块执行顺序&#xff1a;静态代码块 -> 构造代码块 -> 构造函数 -> 普通代码块 继承中代码块执…

linux基本功系列之cd命令实战

文章目录 前言一. cd命令的介绍二. 语法格式及常用选项三. 参考案例总结 前言 居然发现了落下了CD命令&#xff0c;也不算落下把&#xff0c;主要是cd命令内容太少&#xff0c;撑不起一篇文章&#xff0c;今天也写一写&#xff0c;就当记个笔记吧 &#x1f3e0;个人主页&#…

阿里云国际站香港地域服务器访问延迟丢包的原因及解决方法

阿里云百科有2台香港地域的轻量应用服务器&#xff0c;国内使用发现Ping值延迟丢包严重&#xff0c;从大陆到香港访问是经过国际链路和运营商国际路由节点&#xff0c;会受到到国际链路拥塞&#xff0c;以及运营商出境路由限制&#xff0c;导致无法正常连接或访问某些网站&…

ubuntu下,在vscode中使用platformio出现 Can not find working Python 3.6+ Interpreter的问题

有一段时间没有使用platformio了&#xff0c;今天突然使用的时候&#xff0c;发现用不了&#xff0c;报错&#xff1a; Ubuntu PlatformIO: Can not find working Python 3.6 Interpreter. Please install the latest Python 3 and restart VSCode。 上网一查&#xff0c;发现…

新人入职培训感悟

【新世界扬帆】校招新人训练营学习总结_刘珍珍 问题&#xff1a;帮我写一段关于新人入职培训后的感悟&#xff0c;内容需要包括回顾本次新人培训&#xff0c;我参与了哪些课程和活动的学习&#xff1f;在这些内容中&#xff0c;我觉得对我最有帮助的是哪些&#xff1f;这些内容…

使用docker部署node和react应用

使用docker部署node和react应用 Docker 使开发人员能够将所有应用程序打包到容器中。这些容器可以在任何安装了 Docker 的机器上运行&#xff0c;并且应用程序将是相同的。这是在多个系统上运行代码库克隆的好方法&#xff0c;并且我们可以确保它们都是相同的。 在本文中&…

设计模式八:桥接模式(Bridge Pattern)

桥接模式是一种结构型设计模式&#xff0c;用于将抽象与实现分离&#xff0c;使它们可以独立地变化。桥接模式的核心思想是将一个大类或多个紧密相关的类分为两个独立的层次结构&#xff0c;从而实现解耦。 在桥接模式中&#xff0c;存在两个维度的类/对象结构&#xff1a;抽象…

【Liux下6818开发板(ARM)】触摸屏

(꒪ꇴ꒪ ),hello我是祐言博客主页&#xff1a;C语言基础,Linux基础,软件配置领域博主&#x1f30d;快上&#x1f698;&#xff0c;一起学习&#xff01;送给读者的一句鸡汤&#x1f914;&#xff1a;集中起来的意志可以击穿顽石!作者水平很有限&#xff0c;如果发现错误&#x…

Mac Navicat 16试用脚本

一、无限试用脚本如下 #!/bin/bash #/usr/libexec/PlistBuddy -c "print" ~/Library/Preferences/com.navicat.NavicatPremium.plist /usr/libexec/PlistBuddy -c "Delete :91F6C435D172C8163E0689D3DAD3F3E9" ~/Library/Preferences/com.navicat.Navica…

MacOS上用docker运行mongo及mongo-express

MongoDB简介 MongoDB 是一个基于分布式文件存储的数据库。由 C 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。 MongoDB 是一个介于关系数据库和非关系数据库之间的产品&#xff0c;是非关系数据库当中功能最丰富&#xff0c;最像关系数据库的。 前提 要求…

高校陆续拥抱chatgpt,人工智能会给学术带来什么变化会有什么影响

在当今信息爆炸的时代&#xff0c;人工智能在各行各业都发挥着越来越重要的作用&#xff0c;高校教育领域也不例外。最近&#xff0c;越来越多的高校开始陆续拥抱chatgpt&#xff08;Chatbot GPT&#xff09;这一人工智能技术&#xff0c;在学术领域会带来了怎样的变化与影响&a…

【RabbitMQ(day3)】扇形交换机和主题交换机的应用

文章目录 第三种模型&#xff08;Publish/Subscribe 发布/订阅&#xff09;扇型&#xff08;funout&#xff09;交换机Public/Subscribe 模型绑定 第四、第五种模型&#xff08;Routing、Topics&#xff09;第四种模型&#xff08;Routing&#xff09;主题交换机&#xff08;To…