首页 > 代码库 > 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 代码对齐
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。