面试题05. 替换空格
题目描述:请实现一个函数,将一个字符串中的每个空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。
思路:从前向后记录‘ ’数目,从后向前替换‘ ’。
method 时间复杂度为O(n),空间复杂度为O(1);
class Solution {
public:
void replaceSpace(char *str, int length )
{
int count =0;
for (int i=0;i<length;i++)
{
if(str[i]==' ')
count++;
}
for(int i=length-1;i>=0;i--){
if(str[i]!=' ')
{
str[i+2*count]=str[i];
}
else
{
count--;
str[i+2*count]='%';
str[i+2*count+1]='2';
str[i+2*count+2]='0';
}
}
}
};
面试题06. 从头到尾打印链表
题目描述:输入一个链表,按链表从尾到头的顺序返回一个ArrayList。
解法:采用递归
时间复杂度O(n),空间复杂度O(n);
class Solution {
public:
vector<int> value;
vector<int> printListFromTailToHead(ListNode* head) {
ListNode *p=NULL;
p=head;
if(p!=NULL){
if(p->next!=NULL){
printListFromTailToHead(p->next);
}
value.push_back(p->val);
}
return value;
}
};