码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 《LeetCode力扣练习》代码随想录——链表(设计链表---Java)


    《LeetCode力扣练习》代码随想录——链表(设计链表—Java)



    刷题思路来源于 代码随想录

    707. 设计链表
    • 虚拟头结点
      class MyLinkedList {
      
          class ListNode{
      
              int val;
              ListNode next;
      
              ListNode(){
      
              }
      
              ListNode(int val){
                  this.val=val;
              }
      
              ListNode(int val,ListNode next){
                  this.val=val;
                  this.next=next;
              }
      
          }
      
          private int size;
          private ListNode dummyHead;
      
          public MyLinkedList() {
      
              this.size=0;
              this.dummyHead=new ListNode(0,null);
      
          }
          
          public int get(int index) {
      
              if(this.size==0||index>=this.size){
                  return -1;
              }
      
              ListNode current=this.dummyHead.next;
      
              while(index>0){
                  current=current.next;
                  index--;
              }
      
              return current.val;
      
          }
          
          public void addAtHead(int val) {
      
              addAtIndex(0,val);
              return;
      
          }
          
          public void addAtTail(int val) {
      
              addAtIndex(this.size,val);
              return;
      
          }
          
          public void addAtIndex(int index, int val) {
      
              if(index>this.size){
                  return;
              }
      
              ListNode current=this.dummyHead;
      
              while(index>0){
                  current=current.next;
                  index--;
              }
      
              ListNode newNode=new ListNode(val,current.next);
              current.next=newNode;
              this.size++;
      
              return;
      
          }
          
          public void deleteAtIndex(int index) {
      
              if(this.size==0||index>=this.size){
                  return;
              }
      
              ListNode current=this.dummyHead;
      
              while(index>0){
                  current=current.next;
                  index--;
              }
      
              current.next=current.next.next;
              this.size--;
      
              return;
      
          }
      }
      
      /**
       * 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);
       */
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
      • 10
      • 11
      • 12
      • 13
      • 14
      • 15
      • 16
      • 17
      • 18
      • 19
      • 20
      • 21
      • 22
      • 23
      • 24
      • 25
      • 26
      • 27
      • 28
      • 29
      • 30
      • 31
      • 32
      • 33
      • 34
      • 35
      • 36
      • 37
      • 38
      • 39
      • 40
      • 41
      • 42
      • 43
      • 44
      • 45
      • 46
      • 47
      • 48
      • 49
      • 50
      • 51
      • 52
      • 53
      • 54
      • 55
      • 56
      • 57
      • 58
      • 59
      • 60
      • 61
      • 62
      • 63
      • 64
      • 65
      • 66
      • 67
      • 68
      • 69
      • 70
      • 71
      • 72
      • 73
      • 74
      • 75
      • 76
      • 77
      • 78
      • 79
      • 80
      • 81
      • 82
      • 83
      • 84
      • 85
      • 86
      • 87
      • 88
      • 89
      • 90
      • 91
      • 92
      • 93
      • 94
      • 95
      • 96
      • 97
      • 98
      • 99
      • 100
      • 101
      • 102
      • 103
      • 104
      • 105
      • 106
      • 107
      • 108
      • 109
      • 110
      • 111
      • 112
      • 113
      • 114

  • 相关阅读:
    Java之反射机制
    Android视图手册之Service
    30-Spark入门之Spark技术栈讲解、分区、系统架构、算子和任务提交方式
    山区自建房BCD浪涌保护器接线方案(自建房用电防雷)
    安装包 amd,amd64, arm,arm64 都有什么区别
    docker容器技术实战-2
    (1-线性回归问题)RBF神经网络
    LeetCode 每日一题 2023/10/16-2023/10/22
    【ATT&CK】基于ATT&CK识别网络钓鱼攻防战法
    重写muduo网络库开发环境和前期准备
  • 原文地址:https://blog.csdn.net/XRT_knives/article/details/134444581
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号