Error[8]: Undefined offset: 66, File: /www/wwwroot/outofmemory.cn/tmp/plugin_ss_superseo_model_superseo.php, Line: 114
File: /www/wwwroot/outofmemory.cn/tmp/plugin_ss_superseo_model_superseo.php, Line: 473, decode(

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

        则输出“We%20are%20happy.”。

前期分析:

        在拿到题之后 首先是与字符串肯定要与数组或者指针有关系,如果要把字符串所有空格替换成%20的话 空格占一个字符串数组的位置的话%20肯定要占三个,所以字符串的长度是肯定要增加的,增加多少呢 一个空格要增加2个长度,所以增加后的字符串长度值就是原来的长度值加上空格个数乘以2。 

整体思想:

        定义两个数组的标志位,p1 和 p2 ,p1 的位置是原始字符串的末尾,p2的位置是增加空格后的字符串末尾,接下来p1开始减少移动,逐个在移动的过程中的字符复制到p2移动的位置,直到p1减少移动到第一个空格为止,当遇到第一个空格后,p1还需要向前移动1格,此时在p2的位置插入%20,这个长度是3 所以p2需要移动3个,第一次循环就结束了 ,下面就可以继续按照第一次的方式进行复制直到p1 与 p2相等的时候,限制条件是 你必须要输入一个字符串,并且p2不能大于p1 当两者相等时候说明没有空格了 。 

        要想程序的时间复杂度为O(n)的话可以尝试从后面进行复制和替换

 

 

上代码:

#include 
#include 

void replace_str(char arg[],int length){

    if (arg == NULL || length <= 0)
    {
        printf("入参为空,请检查%s,[%d]\n",__func__,__LINE__);
        return;
    }
    
    int old_size = 0;//原本的长度
    int new_size = 0;//增加后的长度
    int count_num= 0;//记录空格的个数
    int i=0;

    while (arg[i] !='')
    {   
        ++old_size;
        if(arg[i]==' '){
            ++count_num;
        }
        ++i;
    }
    
    new_size = old_size + count_num*2;
    
    if(new_size > length){ //防止越界段错误
        return;
    }

    int p_old =old_size;
    int p_new =new_size;

    while(p_old >= 0 && p_new > p_old ){
    //p_old可以等于0是为了 输入字符串的时候可以是单一的一个空格,就可以转换成%20

        if(arg[p_old] == ' '){
            
            arg[p_new--]='0';
            arg[p_new--]='2';
            arg[p_new--]='%';

        }else{

            arg[p_new--]=arg[p_old];
        }

        --p_old;//因为需要多移动一次选择使用--p_old        

    }

}



int main(int argc, char const *argv[])
{
    char arr[100]={0};

    printf("请输入一个含有空格的字符串 >\n");
    fgets(arr,100,stdin);
    arr[strlen(arr)-1]='\0';//吃掉输入的回车,不然在输出的时候会多打印一个空行

    replace_str(arr,100);

    printf("%s\n",arr);

    return 0;
}

 

 <===>)
File: /www/wwwroot/outofmemory.cn/tmp/route_read.php, Line: 126, InsideLink()
File: /www/wwwroot/outofmemory.cn/tmp/index.inc.php, Line: 166, include(/www/wwwroot/outofmemory.cn/tmp/route_read.php)
File: /www/wwwroot/outofmemory.cn/index.php, Line: 30, include(/www/wwwroot/outofmemory.cn/tmp/index.inc.php)
c语言实现字符串空格的替换--详细_C_内存溢出

c语言实现字符串空格的替换--详细

c语言实现字符串空格的替换--详细,第1张

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

        则输出“We%20are%20happy.”。

前期分析:

        在拿到题之后 首先是与字符串肯定要与数组或者指针有关系,如果要把字符串所有空格替换成%20的话 空格占一个字符串数组的位置的话%20肯定要占三个,所以字符串的长度是肯定要增加的,增加多少呢 一个空格要增加2个长度,所以增加后的字符串长度值就是原来的长度值加上空格个数乘以2。 

整体思想:

        定义两个数组的标志位,p1 和 p2 ,p1 的位置是原始字符串的末尾,p2的位置是增加空格后的字符串末尾,接下来p1开始减少移动,逐个在移动的过程中的字符复制到p2移动的位置,直到p1减少移动到第一个空格为止,当遇到第一个空格后,p1还需要向前移动1格,此时在p2的位置插入%20,这个长度是3 所以p2需要移动3个,第一次循环就结束了 ,下面就可以继续按照第一次的方式进行复制直到p1 与 p2相等的时候,限制条件是 你必须要输入一个字符串,并且p2不能大于p1 当两者相等时候说明没有空格了 。 

        要想程序的时间复杂度为O(n)的话可以尝试从后面进行复制和替换

 

 

上代码:

#include 
#include 

void replace_str(char arg[],int length){

    if (arg == NULL || length <= 0)
    {
        printf("入参为空,请检查%s,[%d]\n",__func__,__LINE__);
        return;
    }
    
    int old_size = 0;//原本的长度
    int new_size = 0;//增加后的长度
    int count_num= 0;//记录空格的个数
    int i=0;

    while (arg[i] !='')
    {   
        ++old_size;
        if(arg[i]==' '){
            ++count_num;
        }
        ++i;
    }
    
    new_size = old_size + count_num*2;
    
    if(new_size > length){ //防止越界段错误
        return;
    }

    int p_old =old_size;
    int p_new =new_size;

    while(p_old >= 0 && p_new > p_old ){
    //p_old可以等于0是为了 输入字符串的时候可以是单一的一个空格,就可以转换成%20

        if(arg[p_old] == ' '){
            
            arg[p_new--]='0';
            arg[p_new--]='2';
            arg[p_new--]='%';

        }else{

            arg[p_new--]=arg[p_old];
        }

        --p_old;//因为需要多移动一次选择使用--p_old        

    }

}



int main(int argc, char const *argv[])
{
    char arr[100]={0};

    printf("请输入一个含有空格的字符串 >\n");
    fgets(arr,100,stdin);
    arr[strlen(arr)-1]='\0';//吃掉输入的回车,不然在输出的时候会多打印一个空行

    replace_str(arr,100);

    printf("%s\n",arr);

    return 0;
}

 

 

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/728151.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-26
下一篇 2022-04-26

发表评论

登录后才能评论

评论列表(0条)

保存