1050. 螺旋矩阵(25) C++
发布日期:2021-05-08 02:32:56 浏览次数:26 分类:精选文章

本文共 1185 字,大约阅读时间需要 3 分钟。

本题要求将给定的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

在这里插入图片描述

感觉用哈希表会更快一点,只用了数组,而且写的不够精简……

#include
using namespace std;bool cmp(int a,int b){ return a>b;}int res[10010][10010];int main(){ int n,i; cin>>n; int col = sqrt(n), row; while(n % col){ col--; } row = n / col; int a[n]; for(i=0;i
>a[i]; sort(a,a+n,cmp); int f=0,k=0,p=0,q=0; while(k
res[p][i]) res[p][i]=a[k++]; } f++; } if(k>=n) break; if(f%4==1) { for(i=p;i
res[i][col-p-1]) res[i][col-p-1]=a[k++]; } f++; } if(k>=n) break; if(f%4==2) { for(i=col-p-1;i>=0;i--) { if(a[k]>res[row-p-1][i]) res[row-p-1][i]=a[k++]; } f++; } if(k>=n) break; if(f%4==3) { for(i=row-p-1;i>=0;i--) { if(a[k]>res[i][p]) res[i][p]=a[k++]; } f++; } p++; if(k>=n) break; } for(i=0;i
上一篇:Unity2019以后部分版本找不到Tile Palette的问题
下一篇:javaPrintWriter向输出文件中写入双精度、整数、字符、boolean和String类型的值

发表评论

最新留言

初次前来,多多关照!
[***.217.46.12]2025年04月08日 19时43分06秒