69个经典Web前端面试题和答案详解,双向链表(JavaScript实现,哪里有前端开发培训

this.head.prev = newNode;

newNode.next = this.head;

this.head = newNode;

}else{

//如果插入位置为中间

var index = 0;

var current = this.head;

while(index++ <position){

current = current.next;

}

newNode.next = current;

newNode.prev = current.prev;

current.prev.next = newNode;

current.prev = newNode;

}

this.length += 1;

}

}

}

验证:如果在1位置插入xl,如下所示:

list.insert(1,‘xl’)

console.log(list.toString());

运行结果为:

在这里插入图片描述

验证成功。

4、get(position):获取对应位置的元素


这个方法首先要判断位置是否越界,在不越界的情况下,定义一个临时节点和索引,让这个临时节点的指针指向头结点,遍历临时节点,同时索引自加,如果遍历道德节点的位置等于要获取元素的位置,则临时节点对应位置的元素就是要获得的元素。

DoublyLinkedList.prototype.get = function(position){

if(position<0 || position>=this.length){

return false;

}else{

var index = 0;

var current = this.head;

while(index++ <position){

current = current.next;

}

return current.data;

}

}

验证:查询position = 2的元素

console.log(‘list.get(2):’+list.get(2));

结果为:

在这里插入图片描述

验证成功。

但是,这种查找方式有一个弊端,即只能从前向后查找,在某些情况下效率就会很低,所以我们就可以两头查找,具体查找方式为:当我们要查找的节点的位置小于或等于链表长度的一半,我们就可以从前向后查找,如果要查找的节点的位置大于长度的一半,我们就从后往前查找。实现代码为:

DoublyLinkedList.prototype.get = function(position){

if(position<0 || position>=this.length){

return false;

}else{

var len = Math.floor(this.length/2);

if(position<=len){

var index = 0;

var current = this.head;

while(index++ <position){

current = current.next;

}

}else{

var index = this.length-1;

var current = this.tail;

while(index–>position){

current = current.prev;

}

}

return current.data;

}

}

5、indexOf(element):返回元素在列表中的索引


创建一个临时节点和索引,让临时节点指向头结点,依次向后遍历,同时让索引跟着递增,如果遍历的临时节点所得到的元素等于我们指定的元素,则此时的临时节点的位置就是我们目标位置,该位置的索引就是目标值的索引。

DoublyLinkedList.prototype.indexOf = function(data){

var current = this.head;

var index = 0;

while(current){

if(current.data === data){

return index;

}

current = current.next;

index ++;

}

return -1;

}

在这里插入图片描述

验证成功。

6、 update(position,ele):修改某个位置的元素


首先判断要修改的位置是否越界,在不越界的情况下,定义一个临时节点和索引,让临时节点指向头结点,索引位置为0,遍历临时节点并判断临时节点此时的索引和要修改元素的位置是否相等,如果相等的话,此时临时节点的位置就是要修改元素的位置,可以直接给临时节点的数据域更改元素。

DoublyLinkedList.prototype.update = function(position,newData){

if(position<0 || position>=this.length){

return false;

}else{

var index = 0;

var current = this.head;

while(index++ <position){

current = curent.next;

}

current.data = newData;

return true;

}

}

验证:将0位置的数据换成rc

list.update(0,‘rc’)

console.log(“list.update(0,‘rc’)为:”);

console.log(list.toString());

在这里插入图片描述

验证成功。

7、removeAt(position):从列表的指定位置移除一项


这个方法和insert()方法的思想相似,首先判断是否越界,在不越界的情况下,如果链表只有一个节点,则直接移除该项,让链表的头结点和尾节点均指向空。如果链表有多个节点的情况下,也分为三种情况,操作如下:

DoublyLinkedList.prototype.removeAt = function(position){

if(position<0 || position>=this.length){

return null;

}else{

var current = this.head;

if(this.length ===1){

//链表长度为1

this.head = null;

this.tail = null

}else{//链表长度不为1

if(position === 0){

//删除首位

this.head.next.prev = null;

this.head = this.head.next;

}else if(position === this.length-1){

this.tail.prev.next = null;

this.tail = this.tail.prev;

}else{

var index = 0;

while(index++ <position){

current = current.next;

}

current.prev.next = current.next;

current.next.pre = current.prev;

}

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

总结一下

面试前要精心做好准备,简历上写的知识点和原理都需要准备好,项目上多想想难点和亮点,这是面试时能和别人不一样的地方。

还有就是表现出自己的谦虚好学,以及对于未来持续进阶的规划,企业招人更偏爱稳定的人。

万事开头难,但是程序员这一条路坚持几年后发展空间还是非常大的,一切重在坚持。

为了帮助大家更好更高效的准备面试,特别整理了《前端工程师面试手册》电子稿文件。

前端面试题汇总

一个人可以走的很快,但一群人才能走的更远。如果你从事以下工作或对以下感兴趣,欢迎戳这里加入程序员的圈子,让我们一起学习成长!

AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算

前端面试题汇总*

一个人可以走的很快,但一群人才能走的更远。如果你从事以下工作或对以下感兴趣,欢迎戳这里加入程序员的圈子,让我们一起学习成长!

AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算

  • 13
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值