剑指offer 面试题4 替换空格

E:\arithmetic\BlankTo

复杂度O(n)

#include <stdio.h>
#include <string.h>
void blankToSymbol(char a[]);
int main(int argc, char *argv[])
{
	/*测试用例:a)功能测试; b,c,d,e,f)特殊值(空格在开头,在结尾, 连续两个空格,全空格,没空格);g)负面测试 (空字符串)*/ 
	char a[80] = "we are happy";
	char b[80] = " we are happy";
	char c[80] = "we are happy ";
	char d[80] = "we  are happy";
	char e[80] = "   ";
	char f[80] = "weare";
	char *g = NULL; 
	
	blankToSymbol(a);	
	blankToSymbol(b);
	blankToSymbol(c);
	blankToSymbol(d);
	blankToSymbol(e);
	blankToSymbol(f);
	blankToSymbol(g);
	
	return 0;
	
}

void blankToSymbol(char a[]){//长度不用给 ,自己求 
	if(a == NULL) {//增强鲁棒性 
		printf("blank to symbol failed!\n");
		return;
	}
	int i, j;
	int cntZero = 0;
	int length = 0;//字符串长度,不算\0 
	for(i=0 ; a[i]!='\0' ; i++){
		length++;
		if(a[i] == ' '){
			cntZero++;
		}
	}

	for(i=length, j = length+cntZero*2 ; i>=0,j>=0 ; i--, j--){//计算公式别写错 ,i取到length,即\0 
		if(a[i] != ' '){
			a[j] = a[i];
		}
		else{
			a[j--] = '0';
			a[j--] = '2';
			a[j] = '%';
		}
	}
	printf("%d\n%s\n", strlen(a), a);	
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值