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

临沂专业网站建设设计公司当日网站收录查询统计

临沂专业网站建设设计公司,当日网站收录查询统计,wordpress 自动发邮件,wordpress文章批量编辑器题目: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.jinmujx.cn/news/116970.html

相关文章:

  • 柳州城乡建设管理局网站聊城网站推广公司
  • 北京网站制作公司招聘信息鼓楼网站seo搜索引擎优化
  • 成都建设网站标化最新表格企业员工培训总结
  • 商城网站建设服务器免费发布信息网网站
  • 化妆品网站模板免费下载长春网站建设制作
  • 2016网站设计欣赏网站托管服务商
  • owasp+网站开发百度应用下载
  • 网站网站开发奶茶推广软文200字
  • 百度申诉网站企业推广文案范文
  • 承德公司做网站百度指数峰值查询
  • 有哪些免费建站的网站app网络推广公司
  • 网站后台发邮件四川专业网络推广
  • wordpress 教育seo广告投放是什么意思
  • 如何做高端网站免费人脉推广软件
  • 装饰公司手机网站建设手机打开国外网站app
  • php源代码做网站如何做市场推广方案
  • 领创科技网站开发郑州seo博客
  • 怎么给汽车网站做推广百度首页纯净版
  • 做网站需要看啥书搜索引擎优化心得体会
  • 怎么查网址是不是诈骗网站2022拉新推广平台
  • 外贸论坛网站有哪些全球网站访问量排名
  • 网站开发到上线 多久seo检查工具
  • 江门网站建设方案爱站网关键词查询系统
  • wordpress给页面html后缀抖音seo培训
  • 网站首页置顶是怎么做外链推广论坛
  • seo白帽和黑帽的区别搜索引擎优化的方式有哪些
  • 高档网站模板成都网络推广外包
  • wordpress画廊尺寸多大网站优化推广哪家好
  • 人才交流中心招聘网站建设方案网页设计作品集
  • 免费网站制作视频教程淄博网络推广公司哪家好