剑指offer面试题13扩展:带头指针的单链表的操作
来源:互联网 发布:数据透视分析表怎么用 编辑:程序博客网 时间:2024/06/16 21:10
代码:
//带有头指针的链表操作//2014.7.6#include<iostream>#include<cstdlib>using namespace std;typedef struct node{int data;struct node *next;}Node;void insert_node(Node **pphead,int v){if(*pphead==NULL){*pphead=(Node *)malloc(sizeof(Node));(*pphead)->data=v;(*pphead)->next=NULL;}else{Node *t=*pphead;*pphead=(Node *)malloc(sizeof(Node));(*pphead)->data=v;(*pphead)->next=t;}}//--------------------------------------------------------------------------------------------------------平均时间复杂度为O(1)的节点删除算法void delete_node1(Node **pphead,int v)//参考剑指offer ,面试题13,酷壳linus{Node *pNode=*pphead;while(pNode!=NULL){if(pNode->data==v)break;elsepNode=pNode->next;}if(pNode==NULL)//遍历整个链表,没有找到对应节点{ cout<<"No node with v value exist"<<endl;} //要找的节点是尾节点(或者当链表中只有一个节点,且该节点就是要找的那个节点时)时,//由于无法再用“将要删除节点A的后继节点B的内容赋值给A,并将A的next指针指向B的后继节点,然后free(B)”,//只能用顺序查找的方法找到A的前驱节点C,让C指向A的后继节点else if(pNode->next==NULL){Node *pre=*pphead;while(pre->next!=pNode){pre=pre->next;}pre->next=NULL;free(pNode);pNode=NULL;}//当链表中的节点不是尾结点时,“将要删除节点A的后继节点B的内容赋值给A,并将A的next指针指向B的后继节点,然后free(B)”else{Node *pNext=pNode->next;pNode->next=pNext->next;pNode->data=pNext->data;free(pNext);pNext=NULL;}}//---------------------------------------------------------------------------------------------------------------------------------------//------------------------------------------------------------------------------------------------------------------------时间复杂度为O(n),比较经典的的一种方法void delete_node2(Node **pphead,int v){Node *cur=*pphead;Node *pre=NULL;if(cur==NULL){cout<<"Now ,the link is empty!"<<endl;return;}for( ;cur;pre=cur,cur=cur->next){if(cur->data==v)break;}if(pre==NULL)//要删除的是第一个节点{//Node *pnode=*pphead;*pphead=cur->next;free(cur);}else{pre->next=cur->next;free(cur);}}//---------------------------------------------------------------------------------------------------------------------------------------//----------------------------------------------------------------------------------------利用二级指针进行链表节点的删除,时间复杂度为O(1)//---*********************************该方法是效率最高的一种删除链表节点的方法,利用二级指针进行链表的**************************************void delete_node3(Node **pphead,int v){Node **cur=pphead;for(cur=pphead;*cur;){Node *en=*cur;if(en->data==v){*cur=en->next;free(en);break;}else{cur=&en->next;}}}void print_node(Node **pphead){for(Node *cur=*pphead;cur;cur=cur->next)cout<<cur->data<<" ";cout<<endl;}int main(void){Node *firNode=NULL;for(int i=1;i<=10;i++)insert_node(&firNode,i);print_node(&firNode);delete_node1(&firNode,10);delete_node2(&firNode,1);delete_node3(&firNode,3);delete_node3(&firNode,9);print_node(&firNode);}
0 0
- 剑指offer面试题13扩展:带头指针的单链表的操作
- 剑指Offer----面试题28----扩展:字符的所有组合
- 剑指offer面试题13扩展------Linus:利用二级指针删除单向链表
- 用二级指针操作不带头结点的单链表
- 剑指Offer中面试题28的扩展问题(求字符的所有组合)
- 《剑指offer》面试题16扩展题
- 剑指offer面试题4扩展题目
- 剑指offer面试题28扩展提————字符串的组合
- 剑指Offer----面试题29:扩展----数组中第K小的数字
- 剑指Offer----面试题29:扩展----数组中第K大的数字
- 剑指Offer----面试题35:扩展----删除字符串中所有重复出现的字符 & 变位词
- 剑指offer 面试题35扩展:删除字符串中所有重复出现的字符 (C++版)
- 《剑指Offer》面试题:扑克牌的顺子
- 剑指offer面试题 扑克牌的顺子
- 剑指offer面试题 字符串的排列
- 《剑指offer》的又三个面试题
- 剑指offer面试题2.3.1——数组和指针的区别
- 指针的面试题.
- C#开发Android-文件的读写
- 写了一个程序,分析各个源文件之间的include关系。
- POJ 3176:Cow Bowling
- Android写通讯录 用到的数据库知识
- hdu 1241 Oil Deposits
- 剑指offer面试题13扩展:带头指针的单链表的操作
- 通过端口 1433 连接到主机 localhost 的 TCP/IP 连接失败。错误:“Connection refused: connect。
- Etherpeek监听UDP报文时间戳获取
- libsvm工具箱C++下编程实践1
- ruby on rails学习(一)
- 三种创建二叉树的方式
- 盘位wi为什止得知蹿
- 大牛很通俗地介绍《信号与系统》
- C++ Primer Plus第六版 第五章 编程练习答案