Knowledge:
格式化输出
cout<<setw(5)<<setfill('0')<<a<<b;
//输出5位,右对齐,不足补0
//setw(int n)只是对直接跟在<<后的输出数据起作用,而在之后的<<需要在之前再一次使用setw
//setfill(char x)
//dec 以十进制形式输出整数 常用
//hex 以十六进制形式输出整数
//oct 以八进制形式输出整数
//fixed 以普通小数形式输出浮点数
//scientific以科学计数法形式输出浮点数
//left 左对齐,即在宽度不足时将填充字符添加到右边
//right 右对齐,即在宽度不足时将填充字符添加到左边
//setbase(b) 设置输出整数时的进制,b=8、10 或 16
//setw(w) 指定输出宽度为 w 个字符,或输人字符串时读入 w 个字符
//setfill(c) 在指定输出宽度的情况下,输出的宽度不足时用字符c填充(默认情况是用空格填充)
//setprecision(n) 设置输出浮点数的精度为 n。在使用非 fixed 且非 scientific 方式输出的情况下,n 即为有效数字最多的位数,如果有效数字位数超过 n,则小数部分四舍五人,或自动变为科学计 数法输出并保留一共 n 位有效数字。在使用 fixed 方式和 scientific 方式输出的情况下,n 是小数点后面应保留的位数。
详情参考c++iomanip iomanip
#include<iostream>
#include<algorithm>
#include<cmath>
#include<iomanip>
#include<string>
#include<cassert>
#include<cctype>
#include<memory.h>
#include<cstdio>
#include<sstream>
#include<vector>
#include<set>
#include<map>
#include<stack>
#include<queue>
#include<cstdlib>
using namespace std;
int main()
{
int N = 0,max=0;
while (cin >> N)
{
max = 0; //重置max
vector<string> vec;
for (int it = 0; it < N; it++)
{
string t;cin >> t;
if (t.size()>max)
max = t.size();
vec.push_back(t);
}
sort(vec.begin(), vec.end());
int c = 60 / max;
while (1)
{
if ((c - 1) * 2 + c*max <= 60)
break;
else
c--;
} //保证60宽度内按题意填下字符串 且列尽(column)可能多 行(row)尽可能少
int l = vec.size() / c;
if (vec.size() != l*c)l++; //判断方格是否满格
int i = 0, j = 0;
cout << "------------------------------------------------------------" << endl;
for (i = 1; i <= l; i++)
{
for (j = 0; j < c; j++)
{
if (i + j*l - 1 <= vec.size()-1)
if (j != c - 1)
cout << setw(max + 2) << left << vec[i + j*l-1];
else
cout << setw(max) << left << vec[i + j*l-1];
}
cout << endl;
}
}
return 0;
}