紫书刷题

这篇博客探讨了如何使用C++处理字符串和二维向量,特别是针对UVA-1593题目中涉及的代码对齐问题。文章介绍了通过vector存储数据,维护每列最大长度,以及字符串操作来实现对齐的方法。示例代码展示了如何读取输入,更新最大长度,以及在输出时填充空格以达到对齐效果。
摘要由CSDN通过智能技术生成

紫书刷题(Day2)补题(不是

Alignment of Code UVA - 1593 传送:VJ
题目大意
此题主要考察了vector二维的用法,和记录最大长度的方法,以及一些字符串的操作,对给出的代码进行对齐处理。
主要思路
先用vector储存数据,然后用数组来保存每列的最大长度,并每次循环更新最大值,最后按照要求输出。
具体做法
首先要说的就是vector的二维用法,vector [maxn] 创建一个二维的容器来储存,注意maxn是行数,同时对于动态的vector我们可以用size()函数来返回每行的长度用于下标的记法。

vector<string> lines[1010];
int row=0,maxcol[1010]={0};//行号,每列单词的最长长度

其次就是字符串的处理,这里用到了字符串分流,同时空格隔开,若是有特殊的分割符,则用getline()。

stringstream input(s);
while(input>>st){
         maxcol[lines[row].size()]=max(maxcol[lines[row].size()],(int)st.size());//取最大值
         lines[row].push_back(st);
      }

最后就是字符串的整合,由于我们要把字符串长度一致,故要对字符串后面增加” “空格,因此用到了string()。

st+=string(maxcol[j]-st.size()+1 ,' ');

废话不多说上代码:

#include <iostream>
#include<vector>
#include<sstream>
#include<string>

using namespace std;
string s,st;
vector<string> lines[1010];
int row=0,maxcol[1010]={0};//行号,每列单词的最长长度

int main(){
   while( getline(cin,s) ){
      stringstream input(s);
      while(input>>st){
         maxcol[lines[row].size()]=max(maxcol[lines[row].size()],(int)st.size());//取最大值
         lines[row].push_back(st);
      }
      row++;
   }
   for(int i=0;i<row;i++){//按行输出
      for(int j=0;j<lines[i].size();j++){
            st=lines[i][j];
            if(j!=lines[i].size()-1) st+=string(maxcol[j]-st.size()+1 ,' ');
            cout<<st;
      }
      puts("");//参数是""时则相当于\n
   }
   return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值