热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

链表相关操作

1#include2usingnamespacestd;3typedefstructlist4{5intdata;6structlist*next;7list(

1 #include
2 using namespace std;
3 typedef struct list
4 {
5 int data;
6 struct list* next;
7 list():data(0),next(NULL){}
8 }List;
9
10 //1. 后插法插入数据
11 void insertData(List *p, int data)
12 {
13 if (p == NULL)
14 return;
15
16 //申请空间
17 List *tmp = (List *)malloc(sizeof(List));
18 tmp->data = data;
19 tmp->next = NULL;
20
21 //插入链表
22 while (p->next != NULL)
23 p = p->next;
24 p->next = tmp;
25 }
26 //2. 打印数据
27 void printData(List *p)
28 {
29 while (p != NULL)
30 {
31 cout <data <32 p = p->next;
33 }
34 }
35
36 //3.链表逆序1
37 /*******************************************
38 三个指针,pre,cur,next
39 先保存cur的next到next中;
40 然后cur->next指向前面的;
41 pre和cur向前推进,next只是临时存储cur->next
42 *******************************************/
43 List* revertList(List *p)
44 {
45 List *pre = nullptr;
46 List *next = nullptr;
47 while (p != nullptr)
48 {
49 next = p->next;
50 p->next = pre;
51 pre = p;
52 p = next;
53 }
54 return pre;
55 }
56 //4.链表逆序2
57 /***********************************
58 将链表看成两个结点,头结点和后面整体
59 ***********************************/
60 List* revertList2(List *p)
61 {
62 List *newphead;
63 if ((p == NULL) || (p->next == NULL))
64 return p;
65 newphead = revertList2(p->next);
66 p->next->next = p;
67 p->next = NULL;
68 return newphead;
69 }
70
71
72 int main()
73 {
74 List *phead = new List;
75 for (int i = 0; i <20; i++)
76 {
77 insertData(phead, i);
78 }
79
80 printData(phead);
81
82 phead=revertList(phead);
83
84 printData(phead);
85 cout <<"AAAAAAAAAAAAA" <86 phead = revertList2(phead);
87
88 printData(phead);
89
90
91 return system("pause");
92 }

 



推荐阅读
  • 本文详细探讨了VxWorks操作系统中双向链表和环形缓冲区的实现原理及使用方法,通过具体示例代码加深理解。 ... [详细]
  • 本实验主要探讨了二叉排序树(BST)的基本操作,包括创建、查找和删除节点。通过具体实例和代码实现,详细介绍了如何使用递归和非递归方法进行关键字查找,并展示了删除特定节点后的树结构变化。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本文详细介绍了C语言中链表的两种动态创建方法——头插法和尾插法,包括具体的实现代码和运行示例。通过这些内容,读者可以更好地理解和掌握链表的基本操作。 ... [详细]
  • 本文介绍如何使用Objective-C结合dispatch库进行并发编程,以提高素数计数任务的效率。通过对比纯C代码与引入并发机制后的代码,展示dispatch库的强大功能。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 本题涉及一棵由N个节点组成的树(共有N-1条边),初始时所有节点均为白色。题目要求处理两种操作:一是改变某个节点的颜色(从白变黑或从黑变白);二是查询从根节点到指定节点路径上的第一个黑色节点,若无则输出-1。 ... [详细]
  • Linux设备驱动程序:异步时间操作与调度机制
    本文介绍了Linux内核中的几种异步延迟操作方法,包括内核定时器、tasklet机制和工作队列。这些机制允许在未来的某个时间点执行任务,而无需阻塞当前线程,从而提高系统的响应性和效率。 ... [详细]
  • Codeforces Round #566 (Div. 2) A~F个人题解
    Dashboard-CodeforcesRound#566(Div.2)-CodeforcesA.FillingShapes题意:给你一个的表格,你 ... [详细]
  • 本题通过将每个矩形视为一个节点,根据其相对位置构建拓扑图,并利用深度优先搜索(DFS)或状态压缩动态规划(DP)求解最小涂色次数。本文详细解析了该问题的建模思路与算法实现。 ... [详细]
  • 本题探讨如何通过最大流算法解决农场排水系统的设计问题。题目要求计算从水源点到汇合点的最大水流速率,使用经典的EK(Edmonds-Karp)和Dinic算法进行求解。 ... [详细]
  • 在多线程编程环境中,线程之间共享全局变量可能导致数据竞争和不一致性。为了解决这一问题,Linux提供了线程局部存储(TLS),使每个线程可以拥有独立的变量副本,确保线程间的数据隔离与安全。 ... [详细]
  • ImmutableX Poised to Pioneer Web3 Gaming Revolution
    ImmutableX is set to spearhead the evolution of Web3 gaming, with its innovative technologies and strategic partnerships driving significant advancements in the industry. ... [详细]
author-avatar
倩倩倩倩倩倩雯-
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有