大家好,又见面了,我是全栈君
一 题目:替换空格
题目:请实现一个函数,把字符串中的每个空格替换成“ ”。例如输入‘“We are happy”,则输出“We are happy”.
在网络编程中,如果URL参数中含有特殊字符,如空格、’#’等,可能导致服务器端无法获得正确的参数值。我们需要将这些特殊符号转换成服务器可以识别的字符。转换的规则是在’%’后面跟上ASCII码的两位十六进制的表示。比如空格的ASCII码是32,即十六进制的0x20,因此空格被替换成” ″。再比如’#’的ASCII码为35,即十六进制的0x23,它在URL中被替换为”#″。
二 代码实现
O(n2)解法
最直观的做法是从头到尾扫描字符串,每一次碰到空格字符的时候做替换。由于是把1个字符替换成3个字符,我们必须要把空格后面所有的字符都后移两个字节,否则就有两个字符被覆盖了。
假设字符串的长度是n。对每个空格字符,需要移动后面O(n)个字符,因此对含有O(n)个空格字符的字符串而言总的时间效率是O(n2)。
O(n)解法
代码语言:javascript复制#include "stdio.h"
#include <iostream>
using namespace std;
// 在不适用另外的buff的情况下将空格替换为字符串
char cBuff[100] = "We are happy!";
void ReplaceBlank(char *cBuff)
{
char cVal;
int i = 0;
int nBlankNum = 0; // 统计空格的数目
int nBuffLen = 0;
while((cVal = cBuff[i ]) && (cVal != '