一系列链表题

1、链表的倒序输出:(输出4,3,2,1)在这里,可以使用递归的方式:

<span style="font-size:18px;">void Reverse(pNode pHead)
{if(pHead){Reverse(pHead->next);cout<<pHead->data<<"->";	}
}
</span>
2、删除无头单链表的非尾节点(不能遍历)

思路:目前只给出了删除的位置,既然不能遍历,我们就无法知道删除元素节点的前一个位置。这时候我们可以从它的后一个节点入手,可以删除后一个节点,然后将后一个元素的值保留,赋给前一个节点的值。

如图:



实现代码:

<span style="font-size:18px;">void DeleteListNotTail(pNode *pHead,pNode pos)
{assert(pHead);if(*pHead == NULL || pos->next == NULL)return;pNode pDel = pos->next;pos->next = pDel->next;pos->data = pDel->data;free(pDel);
}</span>
3、在无头单链表的非头节点处插入一个节点(不能遍历)

思路:可以在位置之后插入一个节点,然后交换两个节点的值。



实现代码:

<span style="font-size:18px;">void InsertNotHead(pNode *pHead,pNode pos,DataType data)
{if(*pHead == NULL || pos == *pHead)return;pNode newNode = BuyNode(pos->data);newNode->next = pos->next;pos->next = newNode;pos->data = data;
}</span>

4、查找单链表的中间节点

思路:可以定义快慢两个指针,一个走一步,一个走两步。当快指针到达终点时,慢指针就在中间位置。

在这里,还得分为奇数个节点和偶数个节点。(偶数个节点有两个中间节点哦)


关于偶数个节点,我们该返回哪一个呢,如果返回3,就让pFast指向NULL,如果返回2,就让pFast->next指向NULL;

如果两个都返回的话,就要用一个结构体来接收哦。



实现代码:

<span style="font-size:18px;">pNode FindMidNode(pNode pHead)
{assert(pHead);pNode pFast = pHead;pNode pSlow = pHead;//while(pFast && pFast->next)            //偶数个节点时,中间节点返回后一个//{//	pFast = pFast->next->next;//	pSlow = pSlow->next;//}while(pFast->next && pFast->next->next)  //偶数个节点时,中间节点返回前一个{pFast = pFast->next->next;pSlow = pSlow->next;}return pSlow;
}</span>

5、查找倒数第K个节点(只能遍历一次)

思路:用快慢两个指针,先让快指针先走K步,然后快慢指针一起向前走。当快指针指向NULL的时候,慢指针就指向倒数第K个节点。

这里强调的是走K步和走K-1步。(一个是后置--,一个是前置--,二者是不一样的)

<span style="font-size:18px;">pNode FindLastK(pNode pHead,int k)
{assert(pHead);int count = k;pNode pFast = pHead;pNode pSlow = pHead;if(pHead == NULL || k <= 0)     //边界条件判断return NULL;/*while(count--)            //pFast移动k次{if(pFast == NULL)return NULL;pFast = pFast->next;	}while(pFast){pFast = pFast->next;pSlow = pSlow->next;}*/while(--count)                 //pFast移动k-1次{if(pFast == NULL)return NULL;pFast = pFast->next;	}while(pFast->next){pFast = pFast->next;pSlow = pSlow->next;}return pSlow;
}
</span>

6、单链表的逆置/反转

思路:用三个指针互相转换,用2->1,然后再整体向后移动。直到所有的都链起来。


实现代码:

pNode ReverseList(pNode pHead)      //逆置
{assert(pHead);if(pHead == NULL || pHead->next == NULL)return pHead;pNode pPre = pHead;pNode pCur = pPre->next;pNode pNext = pCur->next;while(pNext){pCur->next = pPre;pPre = pCur;pCur = pNext;pNext = pNext->next;}pCur->next = pPre;pHead->next = NULL;return pCur;
}


之后遇到其他链表题的话还会继续补充哦。 微笑 微笑






本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/382832.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

简陋版C语言仿真通讯录之动态内存开辟版本

简陋版C语言仿真通讯录 https://blog.csdn.net/csdn_kou/article/details/80287640 简陋版C语言仿真通讯录之动态内存开辟版本 给Contact结构体增加一个容量&#xff0c;来表示什么时候增容 #define MAX_NAME 20 typedef struct PeoInfo {char name[MAX_NAME];int age;char …

node.js 代码修改 自动识别重启工具

npm install supervisor -g supervisor xx.js 代替 node xx.js 能实现自动重启服务&#xff0c;识别代码更新

C语言转移表之加减乘除无限进化版

主干程序初级版本进阶版本版本进化 主干程序 输入程序解析程序 /*解析字符串 有空格把空格分开 比如输入&#xff1a;add 1 2 解析后&#xff1a;add12*/ void do_parse(char *buf) {int state 0;int i 0;int argc 0;char *argv[8] {0};for (i 0; buf[i]; i){if (state …

node.js 笔记1 模块方面

url 模块 parse 解析url 可以用来获取查询参数 xx.js exports.xx xx 另一个文件引用 require(’./xx.js); 获取的句柄 相当于 xx.js 中的 exports xx.js module.exports xx 这样被人引用 相当于就是直接拿到了 xx 当require xx 的时候&#xff0c; 如果xx不在当前文件夹 &…

c++之指针引用

指针&#xff1a;指向一块内存地址的标识。 引用&#xff1a;给已经定义的变量起的别名。 格式&#xff1a; 类型 &引用变量名 已定义的变量名&#xff08;引用变量名和已定义的变量名可以看成是同一个实体&#xff0c;一个改变&#xff0c;另一个也随之改变&#xff0…

C语言之scanf中的格式

scanf函数原型控制格式1.%[^\n]%*c例子1例子2 1.%[]例子1例子2 scanf函数原型 int scanf( const char *format, ... ); 见可变参数求和 https://blog.csdn.net/csdn_kou/article/details/79996606 控制格式 %c 一个单一的字符 %d 一个十进制整数 %i 一个整数 %e, %f, %…

node.js 将文件目录读取 通过匿名函数自执行 将异步改为同步

var fs require(fs);var filesarray []; fs.readdir(html, function(error, files){if(error){console.log(error.stack);console.log(--------);console.log(文件夹读取失败);return false;}// 匿名函数自执行&#xff0c; 将异步改为同步(function getFile(i){console.log(…

蛇形数组打印(两种形式)

#蛇形数组打印 ##第一种形式 形式1 51 2 3 4 516 17 18 19 615 24 25 20 714 23 22 21 813 12 11 10 9 请按任意键继续. . .形式2 513 14 15 16 112 23 24 17 211 22 25 18 310 21 20 19…

node.js 获取异步方法里面的数据 =》 两种方式

第一种&#xff1a; 通过回调函数实现&#xff1a; var fs require(fs); function getmime(callback){ fs.readFile(./t1.js, function(err, data){// 现在理解&#xff0c;异步方法里还有别的引用 就不会提前释放callback(data);}); }getmime(function(data){console.log(…

python入门--基本语法

标准数据类型&#xff1a;Number(数字)&#xff0c;String(字符串)&#xff0c;List(列表)&#xff0c;Tuple(元组)&#xff0c;Sets(集合)&#xff0c;Dictionary(字典)Number只支持int(表示长整型)&#xff0c;float&#xff0c;bool&#xff0c;complex&#xff08;复数&…

Linux网站大杂烩《自己查阅》

从网络上拷贝别人归纳的列表。 Linux优秀网站列表 国内 http://www.chinaunix.net/ 国内最火爆的unix/linux论坛 http://www.linuxforum.net/ linux爱好者交流的场所&#xff0c;侧重编程开发 http://www.linuxaid.com.cn/ 面向初学者者提供资料 http://www.ibm.com/de…

python之条件、循环语句

其实&#xff0c;很多语言的语法都是相通的&#xff0c;包括初学python一样。 今天要说的是条件、循环语句。这部分也是相对比较简单的&#xff0c;就python而言&#xff0c;只是书写方式稍作改动罢了。 1、条件语句 &#xff08;1&#xff09;格式&#xff1a; if 判断条件…

node.js Promise简单介绍

转自百度&#xff1a; https://baijiahao.baidu.com/s?id1589455136001194151&wfrspider&forpc

数据结构之空间复杂度和空间复杂度

1.空间复杂度计算方法 2.时间复杂度计算方法非递归递归情况递归总次数*每次递归次数 1.空间复杂度 空间复杂度是指 执行这个算法所需要的内存空间。空间复杂度是函数中创建对象的个数关于问题规模函数表达式&#xff0c;一般情况下用O渐进表示法表示 计算方法 1.忽略常数&…

node.js 获取异步方法里面数据 的方式

第一种 使用回调函数&#xff1a; function getData(callback){setTimeout(function(){var name xxxx;callback(name);}, 1000); }// 外部获取异步方法里面的数据 采用回调函数的方式 getData(function(data){console.log(name); });第二种方式 事件触发&#xff1a; var fs…

C语言malloc和calloc的区别

是否对申请的区域进行初始化而已 但是我想你也知道我们写程序的时候多用malloc而很少用calloc&#xff0c;何解&#xff1f; 因为calloc虽然对内存进行了初始化&#xff08;全部初始化为0&#xff09;&#xff0c;但是同样也要降低效率的 calloc相当于 p malloc(); memse…

node.js将buffer对象转换为json对象

d 是buffer对象 let jsstr JSON.stringify(d);let jsondata JSON.parse(jsstr);let buf new Buffer(jsondata);let data buf.toString();sx JSON.parse(data);console.log(sx[peer_count]);详见百度经验: https://jingyan.baidu.com/article/8ebacdf079f00549f75cd564.htm…

静态多态之泛型编程(模板)

起初&#xff0c;我们写不同类型的加法函数是这样写的吧&#xff1a; //Template.h #pragma onceint Add(const int left,const int right) {return leftright; }char Add(const char left,const char right) {return leftright; }float Add(const float left,const float rig…

网站视频解析 有的url资源放在浏览器能直接播放,有的却不行。

1有的视频url放在浏览器地址栏&#xff0c;回车能直接播放 2.有的视频url却直接下载下来一个 很短暂的m3u8文件&#xff0c; 且不能播放 这时候把视频url放在 vlc 或者专门解析m3u8的网站上却能直接播放&#xff1a; 例如&#xff1a;https://youku.com-l-youku.com/20190207/2…

【数据结构】布隆过滤器原理详解及其代码实现

《博主简介》 小伙伴们好&#xff0c;我是阿旭。专注于人工智能AI、python、计算机视觉相关分享研究。 ✌更多学习资源&#xff0c;可关注公-仲-hao:【阿旭算法与机器学习】&#xff0c;共同学习交流~ &#x1f44d;感谢小伙伴们点赞、关注&#xff01; 《------往期经典推荐--…