leetcode算法总结之字符串除空格操作

给定字符串(ASCII码0-255)数组,请在不开辟额外空间的情况下删除开始和结尾处的空格,并将中间的多个连续的空格合并成一个。例如:"   i    am a      little boy.    ",变成"i am a little boy",语言不限,但不要用伪代码作答,函数输入输出请参考如下的函数原型:

C++函数原型:

void FormatString(char str[],int len){

}

首先是字符串数组操作,不需要再申请内存空间,通过下标访问字符;其次是空格在字符

串中的表示‘ ’,与‘\0’区分开;

'\0'表示字符串结束符,代表字符串结束,而空格是一个普通字符,显示在文本中可以选中。
'\0'的ASCII码为0,空格的ASCII码为32。

代码实现:

void FormatString( char str[],  int len)
{
   if (str == NULL || len <= 0)
   return ;
 
   int i = 0, j = 0;
   while (str[i] ==  ' ' ) //开头的空格
     i++;
   while (str[i] !=  '\0' )
   {
     if (str[i] ==  ' ' && (str[i+1] ==  ' ' || str[i+1] ==  '\0' ))
     {
//中间或者结尾的空格
         i++;
         continue ;
     }
     str[j++] = str[i++];
   }
   str[j] =  '\0' ;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值