如何实现单向链表的逆置
2015-08-10 17:03
351 查看
如何实现单向链表的逆序呢?
开发环境:VS2013
#include <stdio.h>#include <stdlib.h>
struct list
{
int data;
struct list *next;
};
struct list *create_list()//建立一个节点
{
//struct list *p = malloc(sizeof(struct list));
//p->data = 0;
//p->next = NULL;
//return p;
return (struct list *)calloc(sizeof(struct list), 1);
}
void traverse(struct list *ls)//循环遍历链表
{
struct list *p = ls;
while (p)
{
printf("%d\n", p->data);
p = p->next;
}
}
void reverse(struct list *ls)
{
if (ls->next == NULL)
return;
if (ls->next->next == NULL)
return;
struct list *p1 = ls;
struct list *p2 = ls->next;
struct list *p3 = NULL;
struct list *last = ls->next;
while (p2)
{
p3 = p2->next;
p2->next = p1;
p1 = p2;
p2 = p3;
}
last->next = NULL;
ls->next = p1;
}
int main(void)
{
struct list *first = create_list();//创建了一个首节点
int i;
for (i = 0; i < 10; i++)
{
insert_list(first, 0, i);
}
traverse(first);
reverse(first);
traverse(first);
free(first);
system("pause");
return 0;
}
相关文章推荐
- webservice 基于struts2 spring3 hibernate4 cxf2.7
- CSDN博客停站公告
- IOS SDK相机的详细解释/画廊(默认+他们的高清摄像头接口)
- webservice调用dll
- android 代码优化:关闭输出日志
- 同时可以修改时间和日期的datetime_select and 有关时间的转换
- windows live writer Snipped Image Plugin on X64 system
- 避免SQL注入
- C#一些实用的,容易被遗忘的特性,经验和技巧
- 机器学习之实战朴素贝叶斯算法
- oracle 之客户端配置
- 3.1.3 值类型与引用类型的区别
- POJ 1861 && ZOJ 1542--Network 【最小生成树 && kruscal && 水题】
- 链表的排序----链表的归并排序
- HTTP调试工具推荐:Fiddler
- Android ContentValues类
- Intent用法大全
- 实习小结十一:PHP实现每周排名(随排名变化,箭头改变)
- oracle 之总结
- C语言的执行过程