每日一题(字符串分割)

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

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

字符串拆分

题目描述

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

运行结果

(0)

相关推荐