P1050 螺旋矩阵
P1050 螺旋矩阵
转跳点:
1050 螺旋矩阵 (25分)
本题要求将给定的 N 个正整数按非递增的顺序,填入“螺旋矩阵”。所谓“螺旋矩阵”,是指从左上角第 1 个格子开始,按顺时针螺旋方向填充。要求矩阵的规模为 m 行 n 列,满足条件:m×n 等于 N;m≥n;且 m−n 取所有可能值中的最小值。
输入格式:
输入在第 1 行中给出一个正整数 N,第 2 行给出 N 个待填充的正整数。所有数字不超过 104,相邻数字以空格分隔。
输出格式:
输出螺旋矩阵。每行 n 个数字,共 m 行。相邻数字以 1 个空格分隔,行末不得有多余空格。
输入样例:
12
37 76 20 98 76 42 53 95 60 81 58 93
输出样例:
98 95 93
42 37 81
53 20 76
58 60 76
这道题啊,模拟的我好苦啊,我第一波模拟错了3个,打死也就没改出来了,干脆推了重写了一遍,AC了,狗啊,这么AC的都不知道,哭死
这道题没什么好说的,就是碰壁模拟,上下左右四个边界,碰到就转向就可以了。哦,题目说了非递增顺序,记得降序排序哦~
我第一次的代码:
#include <stdio.h>
#include <stdlib.h>
#include <math.h> int matrixsize(int n);
int cmp(const void *a, const void *b) { return (*(int *)a) < (*(int *)b) ? 1 : -1; } int arr[10000], Matrix[10000][1000]; int main(void)
{
int size, n, m;
scanf("%d", &size);
m = matrixsize(size);
n = size / m; for (int i = 0; i < size; i++)
{
scanf("%d", &arr[i]);
} qsort(arr, size, sizeof(arr[0]), cmp); int up = -1, down = m, left = -1, right = n;
int i = 0, j = 0, index = 0;
while (index < size)
{
//向右填充
while (j < right)
{
Matrix[i][j] = arr[index++];
j++;
}
up++;
i++;
j--; //向下填充
while (i < down)
{
Matrix[i][j] = arr[index++];
i++;
}
right--;
i--;
j--; //向左填充
while (j > left)
{
Matrix[i][j] = arr[index++];
j--;
}
down--;
i--;
j++; //向上填充
while (i > up)
{
Matrix[i][j] = arr[index++];
i--;
}
left++;
i++;
j++;
} for (int i = 0; i < m; i++)
{
for (int j = 0; j < n; j++)
{
printf("%d%s", Matrix[i][j], n - 1 == j ? "" : " ");
}
putchar('\n');
} return 0;
} //矩阵的行
int matrixsize(int n)
{
int m;
m = (int)sqrt(n);
if (m - sqrt(n) == 0)
{
return m;
}
m++;
while (0 != n % m)
{
m++;
}
return m;
}
真的是打死也想不出来了,试了5*5, 4*3 ,6*5, 10*10各种,没看出哪错了,模拟题就是恶心……
AC代码:
#include <stdio.h>
#include <stdlib.h>
#include <math.h> int matrixsize(int n);
int cmp(const void *Matrix, const void *b) { return (*(int *)Matrix) < (*(int *)b) ? 1 : -1; } int arr[10000], Matrix[10000][1000]; int main(void)
{
int size, n, m;
scanf("%d", &size);
m = matrixsize(size);
n = size / m; for (int i = 0; i < size; i++)
{
scanf("%d", &arr[i]);
} qsort(arr, size, sizeof(arr[0]), cmp); Matrix[1][1] = arr[0];
int index = 0;
int i = 1, j = 1; //前面已经存了一个了
while (index < size - 1)
{//上下左右四个边界,这次利用了存储值非0的特性,因为上一次有一个越界干脆从1开始
while (j + 1 <= n && !Matrix[i][j + 1])
{
Matrix[i][++j] = arr[++index];
}
while (i + 1 <= m && !Matrix[i + 1][j])
{
Matrix[++i][j] = arr[++index];
}
while (j - 1 > 0 && !Matrix[i][j - 1])
{
Matrix[i][--j] = arr[++index];
}
while (i - 1 > 0 && !Matrix[i - 1][j])
{
Matrix[--i][j] = arr[++index];
}
} for (i = 1; i <= m; i++)
{
for (j = 1; j <= n; j++)
{
printf("%d%s", Matrix[i][j], n == j ? "" : " ");
}
putchar('\n');
} return 0;
} //矩阵的行
int matrixsize(int n)
{
int m;
m = (int)sqrt(n);
if (m - sqrt(n) == 0)
{
return m;
}
m++;
while (0 != n % m)
{
m++;
}
return m;
}
PTA不易,诸君共勉!
P1050 螺旋矩阵的更多相关文章
- PAT 1050. 螺旋矩阵(25)
本题要求将给定的N个正整数按非递增的顺序,填入"螺旋矩阵".所谓"螺旋矩阵",是指从左上角第1个格子开始,按顺时针螺旋方向填充.要求矩阵的规模为m行n列,满足条 ...
- leetcode-Spiral Matrix II 螺旋矩阵2之python大法好,四行就搞定,你敢信?
Spiral Matrix II 螺旋矩阵 Given an integer n, generate a square matrix filled with elements from 1 to n2 ...
- Java-基础编程(螺旋矩阵&乘法表)
package cn.rick.study; import java.io.BufferedReader;import java.io.InputStreamReader;import java.ut ...
- NOIP 2014 普及组 T3 螺旋矩阵
[题意] 已知:n,r,c(n<=30000) 条件:给定n行n列的螺旋矩阵(从矩阵的左上角(1,1)出发,初始时向右移动:如果前方是未曾经过的格子, 则继续前进,否则右转:重复上述操作直至经过 ...
- PAT-乙级-1050. 螺旋矩阵(25)
1050. 螺旋矩阵(25) 时间限制 150 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 本题要求将给定的N个正整数按非递增的 ...
- NOIP2014-普及组复赛-第三题-螺旋矩阵
题目描述 Description 一个n行n列的螺旋矩阵可由如下方法生成: 从矩阵的左上角(第1行第1列)出发,初始时向右移动:如果前方是未曾经过的格子,则继续前进,否则右转:重复上述操作直至经过矩阵 ...
- LeetCode 59. Spiral Matrix II (螺旋矩阵之二)
Given an integer n, generate a square matrix filled with elements from 1 to n2 in spiral order. For ...
- LeetCode 54. Spiral Matrix(螺旋矩阵)
Given a matrix of m x n elements (m rows, n columns), return all elements of the matrix in spiral or ...
- Code Kata:螺旋矩阵 javascript实现
1 2 3 4 5 16 17 18 19 6 15 24 25 20 7 14 23 22 21 8 13 12 11 10 9 如图所示,就是一个5*5的螺旋矩阵 我的思路如下: 第一步:拆分 ...
随机推荐
- 如何启动mac版docker自带的k8s
最近准备好好学习下k8s,为了图方便,直接使用docker集成的k8s,但是网上找了一些教程但都没能一次性成功,只好自己从头跑一遍,顺手写个教程可以方便有类似需求的同学参考. 话不多说,直接上步骤. ...
- 前后端分离后API交互如何保证数据安全性?
一.前言 前后端分离的开发方式,我们以接口为标准来进行推动,定义好接口,各自开发自己的功能,最后进行联调整合.无论是开发原生的APP还是webapp还是PC端的软件,只要是前后端分离的模式,就避免不了 ...
- Spring Boot整合Mybatis(注解方式和XML方式)
其实对我个人而言还是不够熟悉JPA.hibernate,所以觉得这两种框架使用起来好麻烦啊. 一直用的Mybatis作为持久层框架, JPA(Hibernate)主张所有的SQL都用Java代码生成, ...
- STP 指定端口 根端口 区别和理解
不多说,先上图,A为指定端口,B为非指定端口. 看本文的网友应该知道根端口和指定端口的选举,但是对指定端口和根端口的理解不清楚.这里我就略过选举过程,直接描述这两者的区别和存在的意义. 指定端口:转发 ...
- Scrapy 下载文件和图片
我们学习了从网页中爬取信息的方法,这只是爬虫最典型的一种应用,除此之外,下载文件也是实际应用中很常见的一种需求,例如使用爬虫爬取网站中的图片.视频.WORD文档.PDF文件.压缩包等. 1.Files ...
- Mini_Linux需要搭的环境
1.bash:ifconfig:command not found sudo yum install -y net-tools 2.如果Linux系统是通过复制得到 需要更改hostname vi ...
- 浅谈Windows入侵检查
1 准备工作 检查人员应该可以物理接触可疑的系统.因为黑客可能侦测到你可以在检查系统,例如网络监听,所以物理接触会比远程控制更好. 为了当做法庭证据可能需要将硬盘做实体备份.如果需要,断开所有与可 ...
- c# 事件3
1.什么是事件,使对象或者类具有通知功能的成员.//为了解决字段在外部被滥用,推出了事件 事件的功能能=通知+可选的事件参数(具体的详细信息,包括谁发送了消息,发送的什么消息) 使用:用于对象或者类件 ...
- [Android]ListView中分割线的设置
1.在布局文件中ListView元素中通过属性设置 android:divider="#fffff" 分割线颜色 android:dividerHeight="1px& ...
- jquery 操作单选框,复选框,下拉列表实现代码
1.复选框全选操作:其实说到底就是对Jquery 选择器的运用,点我查看Jquery选择器 html代码: 复制代码代码如下: <form> 您爱好的运动是: <input type ...