华为机试在线训练-牛客网(41)字符串分割
2017-03-01 21:59
375 查看
本篇应该是牛客华为机试专题的最后一篇,回顾一下,牛客上的华为专题总计108题,
除去重复题,除去几道bug题,到此为止共记录41道自己认为比较重要的题,欢迎讨论。
有些题还有更好的解法,后续再更新。
连续输入字符串(输出次数为N,字符串长度小于100),请按长度为8拆分每个字符串后输出到新的字符串数组,
长度不是8整数倍的字符串请在后面补数字0,空字符串不处理。
首先输入一个整数,为要输入的字符串个数。
例如:
输入:2
abc
12345789
输出:abc00000
12345678
90000000
接口函数设计如下:
/*****************************************************************************
功能:存储输入的字符创
输入:字符串
输出:无
返回:0表示成功,其它返回-1
******************************************************************************/
int AddString(char *strValue);
/****************************************************************************
功能:获取补位后的二维数组的长度
输入:无
输出:无
返回:二维数组长度
*****************************************************************************/
int GetLength();
/*****************************************************************************
功能:将补位后的二维数组,与输入的二维数组做比较
输入:strInput:输入二维数组,iLen:输入的二维数组的长度
输出:无
返回:若相等,返回0;不相等,返回-1.其它:-1;
******************************************************************************/
int ArrCmp(char strInput[][9],int iLen);
输入描述:
首先输入数字n,表示要输入多少个字符串。连续输入字符串(输出次数为N,字符串长度小于100)。
输出描述:
按长度为8拆分每个字符串后输出到新的字符串数组,长度不是8整数倍的字符串请在后面补数字0,空字符串不处理。
输入例子:
基本思路:长度小于8的字符串直接补0,高于8的字符串按8位长度更间隔split,主要就是string::substr()的使用,需要注意的是取子串时需要分支讨论,当剩余的长度达到8时直接按长度8 取子串,小于8时只能按str.size()-i的长度取子串,然后再补0,否则string::substr()的第二个长度参数越界。
完整AC的代码:
#include <iostream>
#include <vector>
using namespace std;
vector<string> strSplitByLen(string str,int len){
vector<string> res;
if(str.size()<len){
//直接补0
while(str.size()!=len)str+='0';
res.push_back(str);
return res;
}
for(int i=0;i<str.size();i+=len){
string subStr;
if(str.size()-i>=8){
subStr=str.substr(i,len);
}
else{
subStr=str.substr(i,str.size()-i);//不够8位的子串,取剩下所有字符
while(subStr.size()!=len)subStr+='0';//补0
}
res.push_back(subStr);
}
return res;
}
int main(){
int n;
while(cin>>n){
string str;
vector<string> vec_strs;
for(int i=0;i<n;i++){
cin>>str;
vec_strs.push_back(str);
}
for(auto str:vec_strs){
vector<string> vec_out=strSplitByLen(str,8);
for(auto e:vec_out){
cout<<e<<endl;
}
}
}
return 0;
}
除去重复题,除去几道bug题,到此为止共记录41道自己认为比较重要的题,欢迎讨论。
有些题还有更好的解法,后续再更新。
题目描述
连续输入字符串(输出次数为N,字符串长度小于100),请按长度为8拆分每个字符串后输出到新的字符串数组,长度不是8整数倍的字符串请在后面补数字0,空字符串不处理。
首先输入一个整数,为要输入的字符串个数。
例如:
输入:2
abc
12345789
输出:abc00000
12345678
90000000
接口函数设计如下:
/*****************************************************************************
功能:存储输入的字符创
输入:字符串
输出:无
返回:0表示成功,其它返回-1
******************************************************************************/
int AddString(char *strValue);
/****************************************************************************
功能:获取补位后的二维数组的长度
输入:无
输出:无
返回:二维数组长度
*****************************************************************************/
int GetLength();
/*****************************************************************************
功能:将补位后的二维数组,与输入的二维数组做比较
输入:strInput:输入二维数组,iLen:输入的二维数组的长度
输出:无
返回:若相等,返回0;不相等,返回-1.其它:-1;
******************************************************************************/
int ArrCmp(char strInput[][9],int iLen);
输入描述:
首先输入数字n,表示要输入多少个字符串。连续输入字符串(输出次数为N,字符串长度小于100)。
输出描述:
按长度为8拆分每个字符串后输出到新的字符串数组,长度不是8整数倍的字符串请在后面补数字0,空字符串不处理。
输入例子:
2 abc 123456789
基本思路:长度小于8的字符串直接补0,高于8的字符串按8位长度更间隔split,主要就是string::substr()的使用,需要注意的是取子串时需要分支讨论,当剩余的长度达到8时直接按长度8 取子串,小于8时只能按str.size()-i的长度取子串,然后再补0,否则string::substr()的第二个长度参数越界。
完整AC的代码:
#include <iostream>
#include <vector>
using namespace std;
vector<string> strSplitByLen(string str,int len){
vector<string> res;
if(str.size()<len){
//直接补0
while(str.size()!=len)str+='0';
res.push_back(str);
return res;
}
for(int i=0;i<str.size();i+=len){
string subStr;
if(str.size()-i>=8){
subStr=str.substr(i,len);
}
else{
subStr=str.substr(i,str.size()-i);//不够8位的子串,取剩下所有字符
while(subStr.size()!=len)subStr+='0';//补0
}
res.push_back(subStr);
}
return res;
}
int main(){
int n;
while(cin>>n){
string str;
vector<string> vec_strs;
for(int i=0;i<n;i++){
cin>>str;
vec_strs.push_back(str);
}
for(auto str:vec_strs){
vector<string> vec_out=strSplitByLen(str,8);
for(auto e:vec_out){
cout<<e<<endl;
}
}
}
return 0;
}
相关文章推荐
- 华为机试在线训练-牛客网(16)字符串排序
- 华为机试在线训练-牛客网(38)在字符串中找出连续最长的数字串
- 牛客网几道编程题(二)之华为机试在线训练:计算字符个数、字符串最后一个单词的长度、分隔字符串
- 华为机试在线训练-牛客网(3)字符串最后一个单词的长度
- 牛客网--华为机试在线训练1:字符串最后一个单词的长度
- 牛客网华为机试在线训练字符串最后一个单词的长度
- 牛客网–华为机试在线训练4:字符串分隔
- 华为机试在线训练-牛客网(14)删除字符串中出现次数最少的字符
- 华为机试在线训练-牛客网(18)字符串合并处理
- 华为机试在线训练-牛客网(30)查找两个字符串a,b中的最长公共子串
- 华为机试在线训练-牛客网(22)字符串加密
- 华为机试在线训练-牛客网(5)合并表记录
- 华为机试在线训练-牛客网(11)识别有效IP地址和掩码并分类统计
- 华为机试在线训练-牛客网(31)配置文件恢复
- 华为机试在线训练-牛客网(32)成绩排序
- 华为机试在线训练-牛客网(1)明明的随机数
- 华为机试在线训练-牛客网(27)无线OSS-高精度整数加法
- 华为机试在线训练-牛客网(24)迷宫问题
- 牛客网-华为机试在线训练-3.数字颠倒
- 华为机试在线训练-牛客网(2)进制转换