每日一练——L1-032 Left-pad(20 分)

166 阅读2分钟

持续创作,加速成长!这是我参与「掘金日新计划 · 6 月更文挑战」的第12天,点击查看活动详情

题目描述:

根据新浪微博上的消息,有一位开发者不满NPM(Node Package Manager)的做法,收回了自己的开源代码,其中包括一个叫left-pad的模块,就是这个模块把javascript里面的React/Babel干瘫痪了。这是个什么样的模块?就是在字符串前填充一些东西到一定的长度。例如用*去填充字符串GPLT,使之长度为10,调用left-pad的结果就应该是******GPLT。Node社区曾经对left-pad紧急发布了一个替代,被严重吐槽。下面就请你来实现一下这个模块。

输入格式:

输入在第一行给出一个正整数N(≤104)和一个字符,分别是填充结果字符串的长度和用于填充的字符,中间以1个空格分开。第二行给出原始的非空字符串,以回车结束。

输出格式:

在一行中输出结果字符串。

输入样例1:

15 _
I love GPLT

输出样例1:

____I love GPLT

输入样例2:

4 *
this is a sample for cut

输出样例2:

cut

代码长度限制   16 KB

时间限制     400 ms

内存限制     64 MB

PS: 没猜错的话,大家看到这题目十分的兴奋吧,但是大家编程的时候发现——咦?为什么我字符串没输进来,在这我来一一分析~

思路讲解:

1.题目看到了有空格的字符串,相信大家都立马想到了要用getline来对字符串进行处理
2.但是大家没有发现的是,输入char c的时候,有一个回车,什么意思呢,简单来说,字符串string就是'\n'(回车),在这种情况下,字符串的长度时0,你想对它做的操作就无效了
3.所以,这时候我们应该要先用getchar()来“吃掉”回车
4.接着进行下一步的算法对应的解决方案~

代码如下:

#include<iostream>
#include<string>
using namespace std;
int main()
{
	int n;
	char c;
	cin >> n >> c;
	string s;
	getchar();
	getline(cin, s);
	int len = s.size();
	if (n > len) {
		string x;
		//创建一个新的字符串,赋值n-len个c
		x.assign(n - len, c);
		cout << x << s;
	}
	//如果n小于等于len的话,从len-n开始输出
	else {
		for (int i = len - n; i < len; i++) {
			cout << s[i];
		}
	}
}

PS: 用assign赋值的时候别忘了加上string头文件