首页 > 代码库 > uva-1593 代码对齐

uva-1593 代码对齐

题意如下:

输入若干行代码,要求各列单词的左边界对齐且尽量靠左。

单词之间至少要空一格。每个单词不超过80个字符,

每行不超过180个字符,一共最多1000行。

 

注意输出时每行的最后一列后面没有空格符。

 

代码如下:代码中有详细的注释!

#include<iostream>
#include<sstream>
#include<string>
#include<vector>
using namespace std;
vector<string> txt[1314];
string code;
int max_len[250];//将每一列中最长的单词的长度保存下来,以便保证格式!
void print(string s,int len,char extra)
{//格式化输出!
    for(int i=0; i<s.size(); i++)
        cout<<s[i];
    for(int i=0; i<=len-s.size(); i++)
        cout<<' ';
    //cout<<'*';
}
int main()
{
    int col=0,row=0;//代码行数,col表示每一行的“单词”个数!
    while(getline(cin,code))
    {
        stringstream tran(code);//创建一个“字符串流”——tran,接下来只需要像读取cin那样读取tran即可!
        while(tran>>code)
        {
            max_len[col++]=max(max_len[col],(int)code.size());//比较长度取大值。
            txt[row].push_back(code);//将每一个单词存进容器里面!
        }
        row++,col=0;
    }
    for(int i=0; i<row; i++)
    {
        int j=0;
        for(; j<txt[i].size()-1; j++)
            print(txt[i][j],max_len[j],' ');
        cout<<txt[i][j-1]<<endl;//每行的最后一列是不用输出空格的!
    }
    return 0;
}


 

uva-1593 代码对齐