编程是很多偏计算机、人工智能领域必须掌握的一项技能,此编程能力在学习和工作中起着重要的作用。因此小白决定开辟一个新的板块“每日一题”,通过每天一道编程题目来强化和锻炼自己的编程能力(最起码不会忘记编程)

 

特别说明:编程题来自“牛客网”和“领扣”以及热心小伙伴的题目。由于小白有时想锻炼某一类编程方法,所以提供的代码不一定是最优解,但是本文提供的编程代码均为通过测试代码。

 

字符串拆分

题目描述

连续输入字符串,请按长度为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;
}

 

运行结果

 

每日一题(字符串分割)_干货

每日一题(字符串分割)_干货_02

 

每日一题(字符串分割)_干货_03