5-8 Left-pad (20分)
2017-06-22 22:00
141 查看
根据新浪微博上的消息,有一位开发者不满NPM(Node Package Manager)的做法,收回了自己的开源代码,其中包括一个叫left-pad的模块,就是这个模块把javascript里面的React/Babel干瘫痪了。这是个什么样的模块?就是在字符串前填充一些东西到一定的长度。例如用
输入在第一行给出一个正整数
10^4≤104)和一个字符,分别是填充结果字符串的长度和用于填充的字符,中间以1个空格分开。第二行给出原始的非空字符串,以回车结束。
在一行中输出结果字符串。
*去填充字符串
GPLT,使之长度为10,调用left-pad的结果就应该是
******GPLT。Node社区曾经对left-pad紧急发布了一个替代,被严重吐槽。下面就请你来实现一下这个模块。
输入格式:
输入在第一行给出一个正整数N(\le
10^4≤104)和一个字符,分别是填充结果字符串的长度和用于填充的字符,中间以1个空格分开。第二行给出原始的非空字符串,以回车结束。
输出格式:
在一行中输出结果字符串。
输入样例1:
15 _ I love GPLT
输出样例1:
____I love GPLT
输入样例2:
4 * this is a sample forcut
输出样例2:
cut
/* Copyright © 2017年6月22日 18:43:13 by 小闲 */ #include<stdio.h> #include<stdlib.h> #include<string.h> int main() { int i; int a,m; //定义结果的字符串长度a,m为原始字符串的长度 char b; //需要插入的字符 char c[110005]; //原始字符串 scanf("%d %c",&a,&b); //输入整数以及字符 getchar(); //获取缓冲区的回车符 gets(c); //获取原始字符串 m=strlen(c); //获取原始字符串的长度 if(m>=a) //判断输入的长度和原字符串的长度比较 { for(i=m-a;i<=m;i++) //比原字符串小从末尾取位 { printf("%c",c[i]); } } else { for(i=0;i<a-m;i++) //若大于原字符串拼接加入 { printf("%c",b); } printf("%s\n",c); } return 0; }
相关文章推荐
- Left-pad (20分)
- 5-10 Left-pad (20分)
- PAT练习集之20分题-L1-032. Left-pad
- .Net FrameWork String.PadLeft() 、String.PadRight()、String.Substring()方法
- C# string.PadLeft &&String.PadRight方法
- Left-pad
- L1-032. Left-pad
- Javascript 模拟 C#中 PadLeft 和 PadRight 的字符填充实现
- String.PadLeft - 格式对齐
- String扩展 让你在PadLeft和PadRight时不再受单双字节问题困扰
- 论left-pad的实现
- Left-pad
- C#学习之PadLeft的意思
- Left Pad Zero Fill
- C# 中用 PadLeft、PadRight 补足位数
- L1-032. Left-pad
- [转载]实现PadLeft的SQL脚本
- L1-032. Left-pad-PAT团体程序设计天梯赛GPLT
- PAT L1-032. Left-pad
- JavaScript自定义函数:padLeft, Ltrim,Rtrim,alltrim ... more