#include<iostream>
#include<cstdio>
#include<cstring>
#include<sstream>
#include<algorithm>
#include<vector>
#include<iomanip>
using namespace std;
vector<string> word_line[1024];
string line;
int thelong[108];
int main()
{
freopen("1593.in","r",stdin);
freopen("1593.out","w",stdout);
string temp;
int i=0,j=0;
memset(thelong,0,sizeof(thelong));
while (getline(cin,line))
{
stringstream ss(line);
while(ss >> temp)
{
thelong[j]=max(thelong[j],(int)temp.length());
j++;
word_line[i].push_back(temp);
}
i++;j=0;
}
cout << setiosflags(ios::left); //设置宽度 左对齐
for (int k = 0; k < i; k++){
int l = 0;
for ( l; l < word_line[k].size()-1; l++){
cout << setw(thelong[l] + 1) << word_line[k][l];
}
cout << word_line[k][l]<< endl; //每行单词最后一个单词后面不应该有空格输出
}
return 0;
}
这个在前几天就做了,昨天晚上才去想1595的题目,可是代码写出来之后虽然在本机测试没事但是提交之后一直是WA,那么先把这个写出来吧。刚开始的时候,没有办法搞定空格,但是后来在网上看了一下才知道getline()函数可以避开空格的输入,那么就好办了。
思路:用getline()获取到一行字符串之后用流输入到一个字符串不定长数组里面,当然是二维的,用来表示行数,每次输出一次代码就输出空格,知道最后一个直接回车。
代码: