请实现一个简单的字符串替换函数,原字符串需要替换的占位符为“%s”,请按照参数列表的顺序一一替换占位符,若参数列表的字符大于占位符个数,则将剩下的参数字符添加到字符串的结尾。
给定字符串A,同时给定它的长度n及参数字符数组arg,请返回替换后的字符串,保证参数个数大于等于占位符个数。保证原串由大小写英文字母组成,同时长度大小等于500.
测试样例:
“A%sC%sE” ,7 , ['B','D','F']
返回
"ABCDEF"
代码:
#include<iostream>
#include<string>
#include<vector>
#include<assert.h>
using namespace std;
string FormasString(const string& str, int n,const vector<char>& arg,int m)
{
string Forms;
Forms.reserve(str.size());
size_t pos = 0;
size_t i = 0;
for (i; i < n; i++)
{
if (str[i] == '%' && i + 1 < n && str[i + 1] == 's')
{
assert(pos < m);
Forms.push_back(arg[pos++]);
i++;
}
else
Forms.push_back(str[i]);
}
while (pos < m)
{
Forms.push_back(arg[pos++]);
}
return Forms;
}
测试用例:
void Text()
{
string str = "A%sC%sE";
vector<char> arg;
arg.push_back('B');
arg.push_back('D');
arg.push_back('F');
string formatStr = FormasString(str, 7, arg, 3);
cout << formatStr << endl;
formatStr = FormasString(str, 7, arg, 2);
cout << formatStr << endl;
}