首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >每日一题(字符串分割)

每日一题(字符串分割)

作者头像
小白学视觉
发布2019-10-24 02:11:13
5670
发布2019-10-24 02:11:13
举报

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

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

字符串拆分

题目描述

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

运行结果

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-08-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 小白学视觉 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 字符串拆分
    • 题目描述
      • 解析
        • 代码
          • 运行结果
          相关产品与服务
          容器服务
          腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档