只遍历一次,将单链表中的元素顺序反转过来
来源:互联网 发布:数据库如何使用boolean 编辑:程序博客网 时间:2024/05/22 06:08
转载请注明出处。
思想很简单,边遍历边将指针反向,顺便将数据往前移一个单位,这样原来的最后一个节点就变成头节点了。
代码实现如下:
#include<stdio.h>#include<malloc.h>typedef struct LNode {int data;struct LNode *next;}LNode,*linkList;linkList creatLinkList(int n) {//创建一个含n个元素的单链表linkList head = (linkList)malloc(sizeof(LNode));linkList p,q;head->data = n;//记录链表中元素个数q = head;for(int i = 0;i < n;i++) {p = (linkList)malloc(sizeof(LNode));scanf("%d",&p->data);q->next = p;q = p;}q->next = NULL; return head;}void listTraverse(linkList q) {while(q->next) {printf("%d ",q->next->data);q = q->next;}}linkList reverseLinkList(linkList head) {linkList q= head->next,p = NULL;head->next = NULL;while(q){head->data = q->data;//先改数据,反正对指针指向无影响 p = q->next;//q->next要转向用p暂存 q->next = head;//q->next转向 head= q;//head,q向后移动一位 q = p;} return head;}int main() {linkList head = creatLinkList(5);//创建一个含5个元素的单链表printf("创建后遍历:\n");listTraverse(head);printf("\n单链表转置后:\n");head = reverseLinkList(head);listTraverse(head);printf("\n");}
0 0
- 只遍历一次,将单链表中的元素顺序反转过来
- 给定一个链表的头指针,要求只遍历一次,将单链表中的元素顺序反转过来
- 编写一个函数,给定一个头指针,要求只遍历一次,将单链表中的元素反转过来
- 给定一个链表的头指针,要求只遍历一次,将单链表中的元素的顺序翻转过来
- 编写一个函数, 给定一个链表的头指针,要求只遍历一次, 将单链表中的元素顺序翻转过来
- 编写一个函数,给定一个头指针的单链表,要求只遍历一次,将链表中的元素次序反转。
- 遍历一次实现单链表顺序反转
- 遍历一次实现单链表顺序反转
- 遍历一次反转单链表
- 遍历一次反转单链表
- 遍历一次把单链表反转
- 一次遍历反转链表
- 编程之美(一)单链表只遍历一次实现元素反转
- 一次遍历找出单链表中的倒数第k个元素
- 一次遍历完成单链表的反转
- 将链表中的所有元素为奇数的节点移到元素为偶数节点的前面,并使奇数之间顺序反转,偶数之间顺序反转
- 将链表中的所有元素为奇数的节点移到元素为偶数节点的前面,并使奇数之间顺序反转,偶数之间顺序反转。
- 求一个无序数组中的次大数,只遍历一次数组
- JavaScript jQuery (1) 入门
- [deep learning] 最近看过的部分论文
- 游戏服务器开发需要学习的技术
- HeapAlloc,GlobalAlloc,LocalAlloc,VirtualAlloc,malloc,new的异同
- java编写微信公众账号收发消息
- 只遍历一次,将单链表中的元素顺序反转过来
- javascript之jquery基础 选择器
- 深度学习(一)深度学习学习资料
- Visual Studio 相关错误
- PythonChallenge4-7题详解Python版
- javascript之jquery DOM操作
- 游戏主程序亲述游戏职场生涯
- 2045 不容易系列之(3)—— LELE的RPG难题
- 面向对象三要素