UVaOJ 400 - Unix ls

AOAPC I: Beginning Algorithm Contests (Rujia Liu) :: Volume 1. Elementary Problem Solving ::Sorting/Searching


Description

Unix 系统输出文件列表的方式是:

  • 每行最多有60个字符。
  • 最右边一列的长度为文件名长度的最大值。
  • 除了最右边一列, 其他列的长度为文件名长度的最大值 + 2。
  • 文件名按字典序, 从上到下输出。
其他细节参考输出样例。
输入 n 个文件名, 输出 Unix 下的文件列表。


Type

Sorting/Searching


Analysis

文件名排序并不难, 关键是如何输出。


输出时, 依次计算出

列数[= (60 + 2) / 文件名长度的最大值]、

行数[= (n + 列数 - 1) / 列数]。


之后即可方便地输出文件名。


Solution

// UVaOJ 400
// Unix ls
// by A Code Rabbit

#include <algorithm>
#include <iomanip>
#include <iostream>
using namespace std;

const int MAXN = 102;

int n;
string filenames[MAXN];
int max_len;

int main() {
    while (cin >> n) {
        // Input and solve.
        max_len = 0;
        for (int i = 0; i < n; i++) {
            cin >> filenames[i];
            max_len = max((int)filenames[i].length(), max_len);
        }
        sort(filenames, filenames + n);
        // Output.
        for (int i = 0; i < 60; i++)
            cout << '-';
        cout << endl;
        int len_row = max_len + 2;
        int num_col = 62 / len_row;
        int num_row = (n + num_col - 1) / num_col;
        for (int i = 0; i < num_row; i++) {
            for (int j = 0; j < num_col; j++)
                if (j * num_row + i < n)
                    cout << setw(len_row) << left << filenames[j * num_row + i];
            cout << endl;
        }
    }

    return 0;
}

你可能感兴趣的:(UVaOJ 400 - Unix ls)