• Left-pad


    根据新浪微博上的消息,有一位开发者不满NPM(Node Package Manager)的做法,收回了自己的开源代码,其中包括一个叫left-pad的模块,就是这个模块把javascript里面的React/Babel干瘫痪了。这是个什么样的模块?就是在字符串前填充一些东西到一定的长度。例如用*去填充字符串GPLT,使之长度为10,调用left-pad的结果就应该是******GPLT。Node社区曾经对left-pad紧急发布了一个替代,被严重吐槽。下面就请你来实现一下这个模块。
    输入格式:
    输入在第一行给出一个正整数N(≤10​4​​)和一个字符,分别是填充结果字符串的长度和用于填充的字符,中间以1个空格分开。第二行给出原始的非空字符串,以回车结束。
    输出格式:
    在一行中输出结果字符串。
    输入样例1:

    15 _
    I love GPLT

    输出样例1:

    ____I love GPLT

    输入样例2:

    4 *
    this is a sample for cut

    输出样例2:

     cut

    (摘自pintia.cn)

    解答:

     1 #include<iostream>
     2 #include<iomanip>
     3 #include<string>
     4 using namespace std;
     5 int main()
     6 {
     7     char ch;            //输入的字符
     8     unsigned int len;    //输入的长度
     9     string str;            //输入的字符串
    10     cin>>len>>ch;
    11     getchar();            //防止getline()接收'
    ',使用getchar()接收'
    '
    12     getline(cin,str);    //输入一行字符串,包括空格
    13     if(len<str.length())    //输出长度小于字符串长度,则截取字符串
    14     {
    15         string new_str=str.substr(str.length()-len,str.length());    //string.substr()函数截取字符串的部分
    16         cout<<new_str;
    17     }
    18     else                    //输出长度大于字符串长度,则使用setw(int )控制输出长度,使用setfill(char )填充
    19     {
    20         cout<<setw(len)<<setfill(ch)<<str;
    21     }
    22     return 0;
    23 }

    解析:

      见代码注释。

  • 相关阅读:
    CSS旧版flex及兼容
    深入理解CSS弹性盒模型flex
    CSS文本方向
    文本溢出text-overflow和文本阴影text-shadow
    深入理解CSS中的空白符和换行
    CSS中常见的6种文本样式
    理解CSS相对定位和固定定位
    CSS绝对定位的应用
    深入理解CSS绝对定位absolute
    深入理解CSS中的margin负值
  • 原文地址:https://www.cnblogs.com/wzzdeblog/p/10617205.html
Copyright © 2020-2023  润新知