PAT Basic Level 1050 螺旋矩阵 解题思路及AC代码_v0.8.1

2024-03-29 14:18

本文主要是介绍PAT Basic Level 1050 螺旋矩阵 解题思路及AC代码_v0.8.1,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

PAT 乙级 1050 螺旋矩阵 v0.8.1

    • 1. 题目简述及在线测试位置
    • 2. 基本思路
    • 3. 完整AC代码

1. 题目简述及在线测试位置

1.1 给定N个数,按非递增的顺序填入螺旋矩阵中(所谓螺旋矩阵,就是从左上角第1个数开始,按顺时针螺旋方向填充),螺旋矩阵的规模为 m 行 n 列(m×n=N;m≥n;m−n取所有可能值中的最小值)
1.2 在线测试位置: 1050 螺旋矩阵

2. 基本思路

2.0 螺旋矩阵示意图: 从外圈到内圈,按 从左到右、从上到下、从右到左、从下到上的顺序排列
在这里插入图片描述
2.1 需要解决三个问题:A. 将N个数字按非递增的顺序排列 B. 确定螺旋矩阵的行列数 C.将排序后的数字存储到螺旋矩阵中(二维数组)
2.2 问题A通过sort( )函数解决,compare( )要按非递增的顺序编写;问题B 根据条件 “Row × Column =N;Row ≥ Column ;Row − Column 取最小值” 编写代码即可

int ConfirmRow(int N)
{int Row = N, Column = 1, Balance = Row - Column;int Result = Row;while (Row * Row >= N){   //Row − Column 取最小值if (Row - Column < Balance && N % Row == 0){Column = N / Row;Balance = Row - Column;Result = Row;}Row--;}return Result;
}

2.3 对于问题C,需要按螺旋矩阵 从左到右、从上到下、从右到左、从下到上的顺序 将排序后的数字插入到二维数组中。注意边界位置数据的处理(方向转变处),对应代码中的 Up++, Right–, Down–, Left++

int Up = 0, Down = Row - 1, Left = 0, Right = Column - 1;
while (true){for (int i = Left; i <= Right; i++) //Left to Right{b[Up][i] = a[Count++];}if (Count >= N)break;Up++;for (int i = Up; i <= Down; i++) //Up to Down{b[i][Right] = a[Count++];}if (Count >= N)break;Right--;for (int i = Right; i >= Left; i--)//Right to Left{b[Down][i] = a[Count++];}if (Count >= N)break;Down--;for (int i = Down; i >= Up; i--)//Down to Up{b[i][Left] = a[Count++];}if (Count >= N)break;Left++;}

3. 完整AC代码

#include <algorithm>
#include <iostream> 
using namespace std;bool Compare(int a, int b)
{return a > b;
}int ConfirmRow(int N);void Insert_Sort(int a[], int N);int main()
{int N, Row, Column; //Row > Columncin >> N;int a[N], Count = 0;for (int i = 0; i < N; i++)cin >> a[i];sort(a, a + N, Compare);Row = ConfirmRow(N);Column = N / Row;int b[Row][Column];int Up = 0, Down = Row - 1, Left = 0, Right = Column - 1;while (true){for (int i = Left; i <= Right; i++) //Left to Right{b[Up][i] = a[Count++];}if (Count >= N)break;Up++;for (int i = Up; i <= Down; i++) //Up to Down{b[i][Right] = a[Count++];}if (Count >= N)break;Right--;for (int i = Right; i >= Left; i--)//Right to Left{b[Down][i] = a[Count++];}if (Count >= N)break;Down--;for (int i = Down; i >= Up; i--)//Down to Up{b[i][Left] = a[Count++];}if (Count >= N)break;Left++;}for (int i = 0; i < Row; i++){int j = 0;cout << b[i][j];for (j++; j < Column; j++){cout << " " << b[i][j];}cout << endl;}return 0;
}int ConfirmRow(int N)
{int Row = N, Column = 1, Balance = Row - Column;int Result = Row;while (Row * Row >= N){if (Row - Column < Balance && N % Row == 0){Column = N / Row;Balance = Row - Column;Result = Row;}Row--;}return Result;
}

这篇关于PAT Basic Level 1050 螺旋矩阵 解题思路及AC代码_v0.8.1的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

利用Python调试串口的示例代码

《利用Python调试串口的示例代码》在嵌入式开发、物联网设备调试过程中,串口通信是最基础的调试手段本文将带你用Python+ttkbootstrap打造一款高颜值、多功能的串口调试助手,需要的可以了... 目录概述:为什么需要专业的串口调试工具项目架构设计1.1 技术栈选型1.2 关键类说明1.3 线程模

Python Transformers库(NLP处理库)案例代码讲解

《PythonTransformers库(NLP处理库)案例代码讲解》本文介绍transformers库的全面讲解,包含基础知识、高级用法、案例代码及学习路径,内容经过组织,适合不同阶段的学习者,对... 目录一、基础知识1. Transformers 库简介2. 安装与环境配置3. 快速上手示例二、核心模

Java的栈与队列实现代码解析

《Java的栈与队列实现代码解析》栈是常见的线性数据结构,栈的特点是以先进后出的形式,后进先出,先进后出,分为栈底和栈顶,栈应用于内存的分配,表达式求值,存储临时的数据和方法的调用等,本文给大家介绍J... 目录栈的概念(Stack)栈的实现代码队列(Queue)模拟实现队列(双链表实现)循环队列(循环数组

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求

Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码

《Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码》:本文主要介绍Java中日期时间转换的多种方法,包括将Date转换为LocalD... 目录一、Date转LocalDateTime二、Date转LocalDate三、LocalDateTim

jupyter代码块没有运行图标的解决方案

《jupyter代码块没有运行图标的解决方案》:本文主要介绍jupyter代码块没有运行图标的解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录jupyter代码块没有运行图标的解决1.找到Jupyter notebook的系统配置文件2.这时候一般会搜索到

Python获取C++中返回的char*字段的两种思路

《Python获取C++中返回的char*字段的两种思路》有时候需要获取C++函数中返回来的不定长的char*字符串,本文小编为大家找到了两种解决问题的思路,感兴趣的小伙伴可以跟随小编一起学习一下... 有时候需要获取C++函数中返回来的不定长的char*字符串,目前我找到两种解决问题的思路,具体实现如下:

Python通过模块化开发优化代码的技巧分享

《Python通过模块化开发优化代码的技巧分享》模块化开发就是把代码拆成一个个“零件”,该封装封装,该拆分拆分,下面小编就来和大家简单聊聊python如何用模块化开发进行代码优化吧... 目录什么是模块化开发如何拆分代码改进版:拆分成模块让模块更强大:使用 __init__.py你一定会遇到的问题模www.