網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
首先要明確一點(diǎn),利用頭插法建立出來(lái)的單鏈表的輸出都是逆序的(就是和你的輸入順序反著來(lái)的)然后就是要明確生成的新結(jié)點(diǎn)是一個(gè)個(gè)加在某個(gè)結(jié)點(diǎn)的前面的(這個(gè)結(jié)點(diǎn)不一定是頭結(jié)點(diǎn),下面的代碼是插在p的前頭),這就是頭插法。
怎么將結(jié)點(diǎn)一個(gè)個(gè)插入在某個(gè)結(jié)點(diǎn)前面呢?
下面的圖可以比較詳細(xì)的展示出來(lái):
至少對(duì)我來(lái)說(shuō)挺詳細(xì)的哈
p->next=head->next; //一開始 head->next=NULL;?
head->next=p;//然后將p指針指向head結(jié)點(diǎn)指向的下一個(gè)結(jié)點(diǎn)
以下是圖像展示:
然后再在頭結(jié)點(diǎn)的后面插入新的結(jié)點(diǎn)
再執(zhí)行一遍上面的代碼,?然后head后面就連上了新的結(jié)點(diǎn),p原本指向的結(jié)點(diǎn)前面也增加了一個(gè)新的結(jié)點(diǎn),然后p就指向新加入的結(jié)點(diǎn)了。
以下是圖像展示:
注!:要先寫p->next=head->next,然后才能寫head->next=p;因?yàn)槿绻葘慼ead->next=p,然后再寫head->next=p->next,結(jié)果就會(huì)變成head->next原本要指的是插入的結(jié)點(diǎn),然后又p->next=head->next,那?head->next最后指向的就不是要插入的結(jié)點(diǎn)了,變成了p要指向的下一個(gè)結(jié)點(diǎn),而p->next一開始就是NULL。
也就是說(shuō),新的節(jié)點(diǎn)根本就沒(méi)連上去,p的前面根本沒(méi)有插入新的結(jié)點(diǎn),head->next也一直是NULL。(這段看不懂就不看了)
然后就是不斷地重復(fù)上述過(guò)程,在頭節(jié)點(diǎn)和新插入的節(jié)點(diǎn)之間建立聯(lián)系,同時(shí)在新插入的節(jié)點(diǎn)和上一個(gè)插入的節(jié)點(diǎn)之間建立聯(lián)系,最終得到一個(gè)完整的單鏈表。
以下是代碼展示:
#include <bits/stdc++.h>
using namespace std;
//利用頭插法建立的單鏈表輸出都是逆序的
typedef struct node
{
int data;//數(shù)據(jù)域,存放數(shù)據(jù)
struct node *next;//指針域,存放指針,存放后繼結(jié)點(diǎn)的信息
}no;//no是結(jié)構(gòu)體的名字
int main()
{
no *head,*tail,*p;
head=new no;
head->next=NULL;
tail=head;
int n;
cin>>n;
while(n)
{
p=new no;
p->data=n;
p->next=head->next;//第一次的時(shí)候p->next指的是NULL,
//再往后,指的就是頭結(jié)點(diǎn)后面的結(jié)點(diǎn)
head->next=p;//指針p也可以向前移動(dòng)的哦,不一定就是要向后移動(dòng)
cin>>n;
}
p=head->next;
while(p!=NULL)
{
printf("%d ",p->data);
p=p->next;
}
printf("\n");
return 0;
}
原文鏈接:https://blog.csdn.net/nefu_lmy/article/details/118976669
相關(guān)推薦
- 2022-10-06 Python+Scipy實(shí)現(xiàn)自定義任意的概率分布_python
- 2022-09-18 C++?STL反向迭代器的實(shí)現(xiàn)_C 語(yǔ)言
- 2023-07-18 nacos解決shared-configs下的共享配置文件無(wú)法實(shí)時(shí)更新
- 2022-10-18 shell腳本批量將文件復(fù)制到指定的文件夾下_linux shell
- 2022-03-29 redis的list數(shù)據(jù)類型相關(guān)命令介紹及使用_Redis
- 2023-02-07 C#實(shí)現(xiàn)加密bat文件的示例詳解_C#教程
- 2022-10-09 React路由封裝的實(shí)現(xiàn)淺析_React
- 2023-09-18 Mybatis新增數(shù)據(jù),存在就更新,不存在就添加
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支