700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > C++字符串空格替换题

C++字符串空格替换题

时间:2019-07-27 02:41:34

相关推荐

C++字符串空格替换题

在网络编程中,需要将URL参数中含有的特殊字符通过在'%'后加上ASCII码的两位十六进制的方法,转换成服务器端能够识别的字符,如空格的ASCII码为32即16进制的0x20,则需要替换为"%20"。

题目:请实现一个函数,把传入char*字符串中的每个空格替换成"%20",例如输入"We are happy.",则输出"We%20are%20happy."

时间复杂度为O(n)的解法思路:

首先遍历字符串,得到字符串长度originalLength并统计空格数numberOfBlank,可计算出替换后的字符串长度newLength = originalLength+2*numberOfBlank;

从字符串的尾部开始复制并向前移动,用两个下标IndexOfOriginal和IndexOfNew分别标记目前所指的原字符位置和替换后的字符位置;

当IndexOfOriginal指向空格时,IndexOfNew下标所指的字符及其往前1、2个位置分别替换为'0'、'2'、'%',替换完成后IndexOfOriginal向前移动一格,IndexOfNew相应向前移动3格,否则都往前移动一格;

最后在字符串尾部即下标为newLength-1的位置添加'\0'。

代码:

void ReplaceBlank(char str[], int maxLength) {if(str == NULL || maxLength <=0)return;//calculate the new length after replacing and number of Blanksint originalLength = 0;int numberOfBlank = 0;int index = 0;for(index = 0; str[index] != '\0'; index++) {if(str[index] == ' ')++numberOfBlank;}originalLength = index+1;//if the number of blank is 0, nothing changesif(numberOfBlank==0)return;//if the new length exceeds the max lengthint newLength = originalLength+2*numberOfBlank;if (newLength > maxLength) {cout << "new Length exceeds the max Length!" << endl;return;}//start at the character before '\0'int indexOfOriginal = originalLength-2;int indexOfNew = newLength-2;while (indexOfOriginal>=0 && indexOfNew > indexOfOriginal) {if (str[indexOfOriginal] == ' ') {str[indexOfNew--] = '0';str[indexOfNew--] = '2';str[indexOfNew--] = '%';} else {str[indexOfNew--] = str[indexOfOriginal];}--indexOfOriginal;}//add a '\0' at laststr[newLength-1] = '\0';}

完整代码:

#include <iostream>#include <stdio.h>using namespace std;void ReplaceBlank(char str[], int maxLength) {if(str == NULL || maxLength <=0)return;//calculate the new length after replacing and number of Blanksint originalLength = 0;int numberOfBlank = 0;int index = 0;for(index = 0; str[index] != '\0'; index++) {if(str[index] == ' ')++numberOfBlank;}originalLength = index+1;//if the number of blank is 0, nothing changesif(numberOfBlank==0)return;//if the new length exceeds the max lengthint newLength = originalLength+2*numberOfBlank;if (newLength > maxLength) {cout << "new Length exceeds the max Length!" << endl;return;}//start at the character before '\0'int indexOfOriginal = originalLength-2;int indexOfNew = newLength-2;while (indexOfOriginal>=0 && indexOfNew > indexOfOriginal) {if (str[indexOfOriginal] == ' ') {str[indexOfNew--] = '0';str[indexOfNew--] = '2';str[indexOfNew--] = '%';} else {str[indexOfNew--] = str[indexOfOriginal];}--indexOfOriginal;}//add a '\0' at laststr[newLength-1] = '\0';}void test(char str[], int maxLength) {cout << "-----------test-------------" << endl;printf("Original: %s\n", str);ReplaceBlank(str, maxLength);printf("Replaced: %s\n", str);cout << "-----------end---------------" << endl;}int main() {/*char str[50] = "hello world and s";ReplaceBlank(str, 50);printf("%s\n", str);*/char str1[50]="hello world and s";char str2[50]="";char str3[20]="hello world! fdsjkd";char str4[50]=" helloweroddfsd";char str5[50]=" ";test(str1, 50);test(str2, 50);test (NULL, 50);test(str3, 20);test(str4, 50);test(str5, 50);return 0;}

参考资料:《剑指Offer名企面试官精讲典型编程题》

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。