当前位置: 首页 > news >正文

临沂专业网站建设公司电话广州市口碑seo推广外包

临沂专业网站建设公司电话,广州市口碑seo推广外包,可信赖的大良网站建设,wordpress中collapse题目:LeetCode 707.设计链表 你可以选择使用单链表或者双链表,设计并实现自己的链表。 单链表中的节点应该具备两个属性:val 和 next 。val 是当前节点的值,next 是指向下一个节点的指针/引用。 如果是双向链表,则还…

题目:LeetCode 707.设计链表

你可以选择使用单链表或者双链表,设计并实现自己的链表。

单链表中的节点应该具备两个属性:val 和 next 。val 是当前节点的值,next 是指向下一个节点的指针/引用。

如果是双向链表,则还需要属性 prev 以指示链表中的上一个节点。假设链表中的所有节点下标从 0 开始。

实现 MyLinkedList 类:

  • MyLinkedList() 初始化 MyLinkedList 对象。
  • int get(int index) 获取链表中下标为 index 的节点的值。如果下标无效,则返回 -1 。
  • void addAtHead(int val) 将一个值为 val 的节点插入到链表中第一个元素之前。在插入完成后,新节点会成为链表的第一个节点。
  • void addAtTail(int val) 将一个值为 val 的节点追加到链表中作为链表的最后一个元素。
  • void addAtIndex(int index, int val) 将一个值为 val 的节点插入到链表中下标为 index 的节点之前。如果 index 等于链表的长度,那么该节点会被追加到链表的末尾。如果 index 比长度更大,该节点将 不会插入 到链表中。
  • void deleteAtIndex(int index) 如果下标有效,则删除链表中下标为 index 的节点。

示例:

输入
["MyLinkedList", "addAtHead", "addAtTail", "addAtIndex", "get", "deleteAtIndex", "get"]
[[], [1], [3], [1, 2], [1], [1], [1]]
输出
[null, null, null, null, 2, null, 3]解释
MyLinkedList myLinkedList = new MyLinkedList();
myLinkedList.addAtHead(1);
myLinkedList.addAtTail(3);
myLinkedList.addAtIndex(1, 2);    // 链表变为 1->2->3
myLinkedList.get(1);              // 返回 2
myLinkedList.deleteAtIndex(1);    // 现在,链表变为 1->3
myLinkedList.get(1);              // 返回 3

初始代码:

class MyLinkedList {public MyLinkedList() {}public int get(int index) {}public void addAtHead(int val) {}public void addAtTail(int val) {}public void addAtIndex(int index, int val) {}public void deleteAtIndex(int index) {}
}/*** Your MyLinkedList object will be instantiated and called as such:* MyLinkedList obj = new MyLinkedList();* int param_1 = obj.get(index);* obj.addAtHead(val);* obj.addAtTail(val);* obj.addAtIndex(index,val);* obj.deleteAtIndex(index);*/

代码:

class ListNode {int val;ListNode next;ListNode(){}ListNode(int val) {this.val = val;}
}class MyLinkedList {int size = 0;ListNode head;public MyLinkedList() {size = 0;head = new ListNode(-1);}public int get(int index) {//下标无效if(index<0||index>=size) return -1;ListNode cur = head.next;while(index > 0) {cur = cur.next;index--;}return cur.val;}public void addAtHead(int val) {ListNode node = new ListNode(val);node.next = head.next;head.next = node;size++;}public void addAtTail(int val) {ListNode node = new ListNode(val);ListNode cur = head;while(cur.next != null) {cur = cur.next;}cur.next = node;size++;}public void addAtIndex(int index, int val) {ListNode node = new ListNode(val);//下标无效if(index<0||index>size) return;if(index == size) {addAtTail(val);return;}ListNode cur = head.next;while(index > 1) {cur = cur.next;index--;}if(index == 0) {node.next = head.next;head.next = node;}else {node.next = cur.next;cur.next = node;}size++;}public void deleteAtIndex(int index) {//下标无效if(index<0||index>=size) return;ListNode cur = head.next;while(index > 1) {cur = cur.next;index--;}if(index == 0) {head.next = head.next.next;}else {cur.next = cur.next.next;}size--;}
}/*** Your MyLinkedList object will be instantiated and called as such:* MyLinkedList obj = new MyLinkedList();* int param_1 = obj.get(index);* obj.addAtHead(val);* obj.addAtTail(val);* obj.addAtIndex(index,val);* obj.deleteAtIndex(index);*/

思考:

这个题又单独定义了ListNode类是我没想到的,然后就是利用带头结点做的整个功能。

在MyLinkedList类中定义了size和head。功能不复杂,还是注意空指针边界。

http://www.15wanjia.com/news/11642.html

相关文章:

  • 毕业设计代写网站网店营销策划方案ppt
  • 做视频网站可行吗广告营销策划
  • h5制作网站哪个好百度提交网址多久才会收录
  • 服装店网页设计网站模板软件外包公司有哪些
  • 手机智能建网站网络销售模式有哪些
  • wordpress如何换图片不显示西安优化seo托管
  • 快站app制作seo诊断专家
  • 无锡网站优化公司品牌营销推广代运营
  • 高端企业站关键词大全
  • 顺德做网站公司哪家好网络营销方式与工具有哪些
  • 江山做网站惠州网站推广排名
  • 社区网站搭建手机app推广平台
  • 佛山网站建设公司怎么选百度关键词分析工具
  • 设计网站的制作框架淘宝店铺推广
  • 自己的网站可以做淘客吗深圳网络营销怎么推广
  • 织梦做的网站南京seo排名公司
  • 网页视频下载快捷指令seo关键词搜索和优化
  • 滨州做网站的北京百度推广开户
  • 如何快速做一个网站站长素材官网
  • 如何查看一个网站是什么程序做的小红书新媒体营销案例分析
  • 网站和网页北京seo公司有哪些
  • 建设网站的价格是多少舆情监测软件
  • 哈尔滨做设计和网站的公司吗百度竞价推广的优势
  • 宁波大型网站设计公司广州关键词seo
  • 网站开发是培训石家庄seo扣费
  • 自动做效果图的网站网络服务提供者知道或者应当知道
  • wordpress修改404seo搜索优化是什么
  • 网站内容优化的主要方法seo优化销售话术
  • 张家港高端网站制作seo内容优化心得
  • 华为荣耀手机最新款搜索引擎优化的定义是什么