4-替换空格

一、题目描述

请实现一个函数,把字符串里的每个空格替换成"%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;
}



梦想还是要有的,万一实现了呢~~~~ ヾ(◍°∇°◍)ノ゙~~~~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值