代码随想录--链表--设计链表题型
创始人
2024-06-03 08:56:30
0

http://【帮你把链表操作学个通透!LeetCode:707.设计链表-哔哩哔哩】 https://b23.tv/FB07jhU

链表中,为什么要用一个临时指针cur进行操作而不是直接用head,因为我们操作完链表后是需要返回头结点的,如果你用head的话,那可能头结点的值都改了,我们如何返回头结点,所以是用临时指针进行操作。

1.获取第n个节点的值

cur=dummy head->next;

while(n--){

    cur=cur->next;

}

return cur->val;

这里要注意的是cur是=dummy head ->next。
以及while的括号里n的问题。n有时候加1有时候减1,有时候不加不减,要考虑到边界条件。
举个例子,比如链表1-2-3-4,获取第2个节点的值,因为下标是从0开始,所以是获取节点3,刚开始设cur指向1,while循环条件是n大于0。第一轮,n=2,cur指向下一个即2,然后n--=1;然后第二轮,n=1,cur指向下一个即3,然后n--=0;第三轮,n等于0了,所以不进入循环了,最后返回cur->val。
其实这个可以直接考虑极端情况,链表只有一个节点即头结点,然后我们要获取这个头结点即第0个节点。cur指向这个头结点,然后n是0,所以不进入循环,所以返回cur->val即头结点的值。

2.头部插入节点

newnode=new node();

newnode->next=dummy head->next;

dummy head->next=newnode;

size++;

插入节点问题,很多人都会犯顺序的错误,比如先dummy->next=new node ,再new node->next=dummy next。注意你一开始dummy next改为指向new node了,所以dummy next指向head的指针指向已经没有了,然后你后来又要new node->next=dummy next就不对的。所以应该是先new node->next=dummy next,再dummy->next=new node 

3.尾部插入节点

newnode=new node();

cur=dummy head;

while(cur->next!=null){

          cur=cur->next;

}

cur->next=newnode;

newnode->next=null;

size++;

这里注意一下怎么找最后一个节点就可以了。

4.第n个节点前插入节点

newnode=new node();

cur=dummyhead;

while(n--){

    cur=cur->next;

}

newnode->next=cur->next;

cur->next=newnode;

size++;

注意cur是指向第n-1个节点,cur->next才指向第n个节点,这样你才知道第n个节点前的一个节点是谁嘛。
然后怎么找到这第n个节点,while循环,这里又要注意括号里的n,直接考虑极端情况,如果是在头结点前插入,那cur应该等于dummyhead,而不是dummyhead->next,并且是n开始循环不是n+1或者n-1开始循环,比如是头结点前插入,那cur指向虚拟结点,因为n=0,所以不进入循环,所以就能正好让cur指向虚拟结点,cur->next指向头结点。

5.删除第n个节点

cur=dummy head;

while(n--){

cur=cur->next;

  }

cur-next=cur->next->next;

size--;

具体代码可去代码随想录网站看

相关内容

热门资讯

中证A500ETF摩根(560... 8月22日,截止午间收盘,中证A500ETF摩根(560530)涨1.19%,报1.106元,成交额...
A500ETF易方达(1593... 8月22日,截止午间收盘,A500ETF易方达(159361)涨1.28%,报1.104元,成交额1...
何小鹏斥资约2.5亿港元增持小... 每经记者|孙磊    每经编辑|裴健如 8月21日晚间,小鹏汽车发布公告称,公司联...
中证500ETF基金(1593... 8月22日,截止午间收盘,中证500ETF基金(159337)涨0.94%,报1.509元,成交额2...
中证A500ETF华安(159... 8月22日,截止午间收盘,中证A500ETF华安(159359)涨1.15%,报1.139元,成交额...
科创AIETF(588790)... 8月22日,截止午间收盘,科创AIETF(588790)涨4.83%,报0.760元,成交额6.98...
创业板50ETF嘉实(1593... 8月22日,截止午间收盘,创业板50ETF嘉实(159373)涨2.61%,报1.296元,成交额1...
港股异动丨航空股大幅走低 中国... 港股航空股大幅下跌,其中,中国国航跌近7%表现最弱,中国东方航空跌近5%,中国南方航空跌超3%,美兰...
电网设备ETF(159326)... 8月22日,截止午间收盘,电网设备ETF(159326)跌0.25%,报1.198元,成交额409....
红利ETF国企(530880)... 8月22日,截止午间收盘,红利ETF国企(530880)跌0.67%,报1.034元,成交额29.0...