一、题目描述
请实现一个函数,把字符串里的每个空格替换成"%20"。例如
输入:“we are happy”
输出:“we%20are%20happy”
二、解题思路
【提醒】此题给的需求不够明确,不清楚面试官是要求在原串中改动还是可以重新分配内存改动,当然如果是在原串改动的话需要预留足够多的空间存储,否则必然输出会不全。所以这里需要跟面试官再细化下需求
【假设】这里假设面试官的需求是在一个内存预留足够多的原串中替换
循序渐进的面试节奏:
【思路一---时间复杂度O(n^2)】从头到尾扫面字符串,一碰到空格就将空格后面的元素都右移三个,插入20%
【思路二---时间复杂度O(n)】
1)先从头到尾扫一遍字符串,统计空格数,并由此计算出替换后的字符串
长度,用mark_after记录替换后的长度
2)用mark_before记录原串长度
3)mark_before往前挪:
a)遇到非空格字符则将该字符复制到mark_after的位置,mark_after前移1格,mark_before--;
b)遇到空格字符则在mark_after位置依次插入%20,mark_after向前移动3格,mark_before--;
c)当mark_after==mark_before,则空格替换结束
三、解题算法
/************************************************
author:tmw
date:2018-6-27
*************************************************/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
/**
*@param str 原串
*@param length 原串实际申请的内存长度
**/
char* replace_space(char* str, int length)
{
int mark_before = 0;
int mark_after = 0;
int i;
/**先获取原串长度,用mark_before记录原串长度-1**/
int len = strlen(str);
if(len==0) return NULL;
mark_before = len-1;
/**从头至尾遍历字符串,用mark_after记录原串替换后的长度-1**/
mark_after = len-1;
for( i=0; i<len; i++ )
{
if( str[i] == ' ' )
mark_after += 2; /**空格本身就占一格,所以新加2格**/
}
/**!细节:预留空间不够,不操作,直接返回**/
if( mark_after+1 > length ) return NULL;
/**判断mark_before位置上的元素是否为空格,按规则挪动mark_before和mark_after**/
while( mark_after > mark_before )
{
if( str[mark_before] == ' ' )
{
str[mark_after--] = '0';
str[mark_after--] = '2';
str[mark_after--] = '%';
}
else
str[mark_after--] = str[mark_before];
mark_before--;
}
return str;
}
四、测试代码
int main()
{
printf("test!\n");
char str1[50] = "hello,and how are you";
char* n_str1 = (char*)malloc(50*sizeof(char));
printf("原串1:%s\n",str1);
n_str1 = replace_space(str1,50);
printf("新串1:%s\n\n",n_str1);
char str2[50] = "we are happy";
char* n_str2 = (char*)malloc(50*sizeof(char));
printf("原串2:%s\n",str2);
n_str2 = replace_space(str2,50);
printf("新串2:%s\n\n",n_str2);
char str3[60] = "allaa en haluo motuo zheshi yige ces a a ";
char* n_str3 = (char*)malloc(60*sizeof(char));
printf("原串3:%s\n",str3);
n_str3 = replace_space(str3,60);
printf("新串3:%s\n\n",n_str3);
char str4[14] = "ces ces ces";
char* n_str4 = (char*)malloc(14*sizeof(char));
printf("原串4:%s\n",str4);
n_str4 = replace_space(str4,14);
printf("新串4:%s\n\n",n_str4);
return 0;
}
梦想还是要有的,万一实现了呢~~~~ ヾ(◍°∇°◍)ノ゙~~~~