<pre name="code" class="cpp">#include<iostream>
#include<string>
#include<algorithm>
using namespace std;
const int maxcol = 60;
const int maxn = 100 + 5;
string filenames[maxn];//字符数组,里面存的就是文件名
//输出字符串s,长度不足len时补字符extra
void print(const string& s,int len, char extra) {
cout << s;
for(int i = 0; i < len-s.length(); i++)
cout << extra;
}
int main()
{
int n;
while(cin >> n) {
int M = 0;
for(int i = 0; i < n; i++) {
cin >> filenames[i];
M = max(M, (int)filenames[i].length());//这一步可以找出最长的文件名
}
int cols = (maxcol - M) / (M + 2) + 1, rows = (n - 1) / cols + 1;
// 求出列数cols和行数rows
print("", 60, '-');
cout << "\n";
sort(filenames, filenames+n);//按ASCII码排序
for(int r = 0; r < rows; r++) {
for(int c = 0; c < cols; c++) {
int idx = c * rows + r;
if(idx < n) print(filenames[idx], c == cols - 1 ? M : M+2, ' ');//输出
}
cout << "\n";
}
}
return 0;
}
UVA400 Unix Is
最新推荐文章于 2024-06-27 19:43:51 发布
本文介绍了一个使用C++编写的程序,该程序能够读取一定数量的文件名,按ASCII码顺序排序,并以整齐的表格形式输出这些文件名。程序通过计算最长的文件名来确定输出格式,确保所有文件名在输出时对齐。
700

被折叠的 条评论
为什么被折叠?



