剑指offer 四

字符串


字符串是由若干个字符组成的序列。由于字符串在编程时使用的频率非常高,所以为了优化,很多语言都对字符串做了特殊的规定。

C/C++中每个字符串都以字符 '\0' 作为结尾,这样我们就能很方便的找到字符串的最后尾部。但是由于这一点,每个字符串中都有一个额外的字符的开销,稍不留神就会造成字符串的越界。


还有个知识点,为了节省内存,C/C++把常量字符串放到单独的一个内存区域。那么当几个指针赋值给相同的常量字符串时,他们实际上会指向相同的内存地址。但是,用常量字符串来初始化数组时,确实每个都复制一遍,数组位置各不同。

char str1[]="hello world";
char str2[]="hello world";

char *str3="hello world";
char *str4="hello world";

if(str1==str2)
  printf("str1 and str2 are same");
else
  printf("str1 and str2 are not same");

if(str3==str4)
  printf("str3 and str4 are same");
else
  printf("str3 and str4 are not same");
结果是 “str1 and str2 are not same”  "str3 and str4 are same"

面试题4:替换空格

要求:实现一个函数,把字符串中的每个空格替换成“%20”。如输入“we are happy”,输出“we%20are%20happy”.

题目是有实际应用的在网络编程中,请求URL参数一般需要字符的替换。这里最明显的想法是从头到尾遇到空格进行替换,但是仔细考虑会有多段字符串有重复移动的操作。所以,更好的想法是从尾向头进行,一个前提是知道新的尾在哪,所以首先遍历字符串统计空格数,得到替换后的字符串应该的长度。


我们从字符串的后面开始复制和替换。首先准备两个指针,P1和P2。P1指向原始字符串的末尾,而P2指向替换之后的字符串的末尾。接下来我们向前移动指针P1,逐个把它指向的字符复制到P2指向的位置,直到碰到第一个空格为止。碰到第一个空格之后把P1向前移动一格,在P2之前插入字符串“%20”。同时把P2向前移动3格。






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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值