题意很简单,就是把每个单词按照一定格式输出出来。刚看上去比较麻烦,感觉输出好困难,其实仔细看下,就是每一列的单词长度都是一样的,单词不足个数的用空格来补齐,最后一列不输出空格,只输出单词。

所以思路就很明确了:

1.开一个数组记录每一列单词的最大长度。

2.因为单词是有空格分隔开的,所以可以直接用stringstream,这个在第五章开始有讲到的,把单词存进一个vector<string>里,在一个一个输出,注意最后没有空格就可以了!

代码如下:

#include<sstream>
#include<iostream>
#include<string>
#include<cstring>
#include<cstdio>
#include<vector>
using namespace std;
const int maxn = 1000 + 10;
int str_col_len[maxn];
vector<string>String[maxn];
int main()
{
   // freopen("out.txt","w",stdout);
    string text,code;
    memset(str_col_len,0,sizeof(str_col_len));
    int col=0,row=0;
    while(getline(cin,text)){
        stringstream ss(text);
        String[row].clear();
        while(ss >> code){
            str_col_len[col]=max(str_col_len[col],(int)code.size());
            String[row].push_back(code);
            col++;
        }
        row++;col=0;
    }
    for (int i = 0; i < row; ++i){
        for (int k = 0; k < (int)String[i].size(); ++k){
            cout<<String[i][k];
            if (k<(int)String[i].size()-1)for (int j = 0; j < str_col_len[k]-(int)String[i][k].size()+1;++j)cout<<" ";
        }
        cout<<endl;
    }
    return 0;
}