每日一题(字符串分割)
编程是很多偏计算机、人工智能领域必须掌握的一项技能,此编程能力在学习和工作中起着重要的作用。因此小白决定开辟一个新的板块“每日一题”,通过每天一道编程题目来强化和锻炼自己的编程能力(最起码不会忘记编程)
特别说明:编程题来自“牛客网”和“领扣”以及热心小伙伴的题目。由于小白有时想锻炼某一类编程方法,所以提供的代码不一定是最优解,但是本文提供的编程代码均为通过测试代码。
字符串拆分
题目描述
连续输入字符串,请按长度为8拆分每个字符串后输出到新的字符串数组;
·长度不是8整数倍的字符串请在后面补数字0,空字符串不处理。
输入描述
连续输入字符串(输入2次,每个字符串长度小于100)
输出描述
输出到长度为8的新字符串数组
示例1
输入
abc
123456789
输出
abc00000
12345678
90000000
解析:
本题的目的是将字符数分解成多个长度为8的子字符串,对不足8个的情况,用“0”来填充补齐长度8.因此我们需要判断字符串长度除以8之后的商和余数。如果余数不为零,则说明原字符串肢解之后需要用“0”来补齐。关键问题是如何确定从哪里分割,这里可以使用迭代器来实现字符串的分解。另外从输入示例可以看出,两个字符串的长度是分开计算。我们将分解后的子字符串放在vector容器内,方便之后的输出。
代码:
#include <iostream>
#include <string>
#include <vector>
using namespace std;
int main()
{
string str;
while (cin>>str)
{
vector<string> v_str;
if (str.empty())
continue;
int n=str.size()/8;
int m=str.size()%8;
for (int i = 0; i < n; i++)
{
v_str.push_back(string(str.cbegin() + i * 8, str.cbegin() + i * 8 + 8));
}
if (m>0)
{
string str_sub(str.begin() + n * 8, str.end());
for (int i = 8 - m; i != 0; i--)
{
str_sub = str_sub + "0";
}
v_str.push_back(str_sub);
}
for (auto i : v_str)
{
cout << i << endl;
}
}
return 0;
}
运行结果