人类总是喜欢以偏概全的去找出某些因果关系去说服自己
前言
分值20分,在20分的这档里面算是比较简单的,下面看看怎么做吧
L1-032 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
OK,以上就是题目的所有内容,我们先读题,这就是一个按照要求长度输出一个字符串的题目,分别来看两个样例
输入样例1是给出了一个目标长度大于原有长度的几个参数,然后给出一个给定的字符去填充到前面,这个很好理解
样例2就有点小坑,博主一开始没有看懂,看着,目标长度小于原有长度,然后我就认为是:如果目标长度小于原有长度,就输出cut
,这么看的话那必是错的,仔细看看的话,cut
前面又一个空格,然后再看看输入进去的字符串,输出的字符串是输入的字符串的后四位,这样就可以理解了。
那下面看看代码
代码
#include <stdio.h>
#include <string.h>
int main()
{
int n,i;
char m;
scanf("%d %c\n",&n,&m);//输入第一行的两个变量
char zfc[65535] = {0};
gets(zfc);//输入第二行的字符串
int num = strlen(zfc);//求已有的字符串长度
if(n > num)//判断如果目标长度大于已有长度输出
{
for(i = 0; i < n-num;i++)printf("%c",m);
printf("%s",zfc);
}
else if(n < num)//判断已有大于目标长度输出
for(i = num - n; i < num;i++)printf("%c",zfc[i]);
else printf("%s",zfc);//已有和目标长度相同输出
}
以上所有代码均为自己编写,本人水平有限,如果有哪里出错或者有更好的解法可以与我私信或在评论区里进行讨论