1105. Spiral Matrix (25)模拟——PAT (Advanced Level) Practise

Posted 闲云阁

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了1105. Spiral Matrix (25)模拟——PAT (Advanced Level) Practise相关的知识,希望对你有一定的参考价值。

题目信息

1105. Spiral Matrix (25)

时间限制150 ms
内存限制65536 kB
代码长度限制16000 B
This time your job is to fill a sequence of N positive integers into a spiral matrix in non-increasing order. A spiral matrix is filled in from the first element at the upper-left corner, then move in a clockwise spiral. The matrix has m rows and n columns, where m and n satisfy the following: m*n must be equal to N; m>=n; and m-n is the minimum of all the possible values.

Input Specification:

Each input file contains one test case. For each case, the first line gives a positive integer N. Then the next line contains N positive integers to be filled into the spiral matrix. All the numbers are no more than 10^4. The numbers in a line are separated by spaces.

Output Specification:

For each test case, output the resulting matrix in m lines, each contains n numbers. There must be exactly 1 space between two adjacent numbers, and no extra space at the end of each line.

Sample Input:
12
37 76 20 98 76 42 53 95 60 81 58 93
Sample Output:
98 95 93
42 37 81
53 20 76
58 60 76

解题思路

搜索模拟

AC代码

#include <cstdio>
#include <vector>
#include <cmath>
#include <algorithm>
#include <functional>
using namespace std;
vector<vector<int> > mp;
vector<int> v;
int T, t, m, n;
int dir[4][2] = 1, 0, 0, -1, -1, 0, 0, 1;
int did = 0;
void fill(int x, int y, int p)
    while (p < v.size())
        mp[y][x] = v[p++];
        if (mp[y + dir[did][1]][x + dir[did][0]] > 0)
            did = (did + 1)%4;
        
        x += dir[did][0];
        y += dir[did][1];
    

int main()

    int T, t;
    scanf("%d", &T);
    for (int i = 0; i < T; ++i)
        scanf("%d", &t);
        v.push_back(t);
    
    sort(v.begin(), v.end(), greater<int>());
    n = (int)sqrt(T);
    while (n > 1 && T%n != 0)
        --n;
    

    m = T/n;
    mp.resize(m + 2);
    for (int i = 0; i < m + 2; ++i)
        if (i == 0 || i == m + 1)
            mp[i].assign(n + 2, 1);
        else
            mp[i].assign(n + 2, 0);
        
        mp[i][0] = mp[i][n + 1] = 1;
    
    fill(1, m, 0);
    for (int i = m; i >= 1; --i)
        printf("%d", mp[i][1]);
        for (int j = 2; j <= n; ++j)
            printf(" %d", mp[i][j]);
        
        printf("\\n");
    
    return 0;

以上是关于1105. Spiral Matrix (25)模拟——PAT (Advanced Level) Practise的主要内容,如果未能解决你的问题,请参考以下文章