时间:2021-05-02
字符串逆序
上次面试碰到一个单向链表逆序的题目,幸好对字符串逆序比较熟悉,类比做出来了。字符串逆序比较简单,直接上代码:
调用示例:
? 1 stringReverse(str,str+strlen(str)-1); 单向链表逆序
先上三幅图:原始状态是图一,全部逆序之后是图三的样子,图二是逆序一步之后的样子。按照图二的步骤依次往后,每次移动一步,把p1->next 反向,直到全部逆序。详细原理请看代码。
图一:
图二:
图三:
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 typedef struct Node Node; struct Node{ int data; Node* next; }; Node* reverseLinkList(Node* head){ if (head==NULL||head->next==NULL) { return head; } Node* p1 = head; Node* p2 = p1->next; Node* p3 = p2->next; p1->next = NULL;//p1要变成尾指针,所以指向NULL while (p3!=NULL) { p2->next = p1;//p2->next 反向 p1=p2;//p1指针向后移动一步 p2=p3;//p2指针向后移动一步 p3=p3->next;//p3指针向后移动一步 } p2->next=p1;//p3指向了NULL,p2反向 head=p2;//头指针指向之前的尾指针 return head; }至此结束了。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
C语言中字符串实现逆序实例详解字符串逆序和正序的实现代码:#include#include#include#include#includetyped
C/C++实现递归和栈逆序字符串的实例递归函数调用模型逆序方法voidrevers(char*buf){char*p=buf;if(p==NULL){retur
本文实例为大家分享了Python/C++实现字符串逆序的具体代码,供大家参考,具体内容如下题目描述:将字符串逆序输出Python实现一:借助于列表的revers
本文实例总结了PHP字符串逆序排列实现方法。分享给大家供大家参考,具体如下:关于字符串的逆序排列,最简单的使用PHP函数strrev()的测试代码如下:head
C语言数据结构实现链表逆序并输出将一个链表逆序并输出。我用了两种方法来实现,第一种是借助了一个新的空链表;第二种是在原来链表的基础上直接实现逆序。实例代码:头文