力扣刷题【第一期】

news2024/12/24 21:58:07

文章目录

      • 1.爬楼梯
      • 2.求两数的和(283)
      • 3.移动零(283)
        • 3.1 题目描述
        • 3.2 算法描述
        • 3.3具体实现
      • 4.合并有序连表(21)
        • 4.1 题目描述
        • 4.2 算法思想
        • 4.3 代码实现
      • 5.删除连表中重复的值(83)
        • 5.1 题目描述
        • 5.2 算法思想
        • 5.3 代码实现
      • 6.环形连表(141)
        • 6.1 题目描述
        • 4.2 算法思想
        • 6.3 代码实现
      • 7.相交链表(160)
        • 7.1 题目描述
        • 7.2 算法思想
        • 7.3 代码实现

1.爬楼梯

假设你正在爬楼梯。需要 n 阶你才能到达楼顶。
每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?

在这里插入图片描述

在这里插入图片描述

class Solution {
public:
    int climbStairs(int n) {
      if(n==1) return 1;
      if(n==2) return 2;
      int result=0;
      int pre=2;
      int prePre=1;
      for(int i=3;i<=n;i++){
          result=pre+prePre;
          prePre=pre;
          pre=result;
      }
     return result;
    }
};

2.求两数的和(283)

给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。

class Solution {
    public int[] twoSum(int[] nums, int target) {
        int[] result = new int[2];
        for (int i=0;i<nums.length;i++){
            for(int j=i+1;j<nums.length;j++){
                if(nums[i]+nums[j]==target){
                    result[0]=i;
                    result[1]=j;
                     return result;
                }
            }
        }
            return result;
    }
}

3.移动零(283)

3.1 题目描述

给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。

3.2 算法描述

本题目采用双指针,i和j
1.i和j指向第一个元素,i先后移动当i的值不为0时,将i的值赋值给j,同j向后移动。
2.当i遍历结束时,j的数据代表的是数组中为0 的个数。
3.在遍历数组将后面的数组该为0

3.3具体实现

class Solution {
    public void moveZeroes(int[] nums) {
       if(nums==null)
       {
         return ;
       }
       int j=0;
       for(int i=0;i<nums.length;i++){
           if(nums[i]!=0){
              nums[j]=nums[i];
              j++;
           }
       }
       for(int i=j;i<nums.length;i++){
           nums[i]=0;
       }
    }
}

4.合并有序连表(21)

4.1 题目描述

将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。

4.2 算法思想

1.定义一个新的节点p
2.判断list1和list2如果为空,则直接返回不为空的连表。
3.当list1和list2同时不为空时,判断如果list1<list2,则将p指针指向list1,同时list1向左移动。p指针也向做移动。反之。
3.当list1和list2不满足条件时,list1或者list2还为遍历完毕。则将p指针指向list1或者list2.

4.3 代码实现

class Solution {
    public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
       if(list1==null) return list2; // 为空返回list2
       if(list2==null) return list1;
       ListNode resultNode=new ListNode(0);
       ListNode p=resultNode;
       while(list1!=null && list2!=null){
           if(list1.val < list2.val){
               p.next=list1;
               list1=list1.next;
           }else{
               p.next=list2;
               list2=list2.next;
           }
           p=p.next;
       }
       if(list1!=null){ // list1还未遍历完,将其与的直接到p的后面
           p.next=list1;
       }
       if(list2!=null){
           p.next=list2;
       }
       return resultNode.next;
    }
}

5.删除连表中重复的值(83)

5.1 题目描述

给定一个已排序的链表的头 head , 删除所有重复的元素,使每个元素只出现一次 。返回 已排序的链表 。

5.2 算法思想

1.比较当前节点的值与下一个节点的值。
2.若相同则,将当前节点的指针指向下一个节点的下一个下一个节点。
3.若不同则移动指针。

5.3 代码实现

class Solution {
    public ListNode deleteDuplicates(ListNode head) {
      if(head==null){
        return head;
      }
      ListNode l=head;
      while(l.next!=null){
          if(l.val==l.next.val){
            l.next=l.next.next;
          }else{
             l=l.next;
          }
      }
      return head;
    }
}

6.环形连表(141)

6.1 题目描述

给你一个链表的头节点 head ,判断链表中是否有环。

4.2 算法思想

1.设置p和q指针,q是快指针,每次移动两个,q是慢指针每次移动一个。
2.循环遍历链表,若p==q则链表中存在环。

6.3 代码实现

public class Solution {
    public boolean hasCycle(ListNode head) {
        if(head==null) return false;
        ListNode p=head,q=p;
        while(p.next!=null && p.next.next!=null){
                p=p.next.next;
                q=q.next;
               if(p==q){
                return true;
            }
        }
        return false;
    }
}

7.相交链表(160)

7.1 题目描述

给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点,返回 null 。
在这里插入图片描述

7.2 算法思想

1.分别计算出a和b链表的长度。
2.计算出a和b长度的差。
3.让a或者b先移动d个单位的指针。
4.此时a和b指针起始位置已经相同。

7.3 代码实现

public class Solution {
    public ListNode getIntersectionNode(ListNode headA, ListNode headB) {
        int l1=0,l2=0,d=0;
        ListNode head1=headA,head2=headB;
        while(head1.next!=null){
            l1++;
            head1=head1.next;
        }
        while(head2.next!=null){
            l2++;
            head2=head2.next;
        }
        if(l1<l2){
            head1=headB;head2=headA;d=l2-l1;

        }
        if(l1>l2){
            head1=headA;head2=headB;d=l1-l2;
        }
        for(int i=0;i<d;i++){
            head1=head1.next;
        }
        while(head1.next!=null&&head2.next!=null){
            if(head1==head2)
                return head1;
            head1=head1.next;
            head2=head2.next;
        }
        return null;
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/603193.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CodeEditor之sublimetext:sublimetext的简介、安装、使用方法之详细攻略

CodeEditor之sublimetext&#xff1a;sublimetext的简介、安装、使用方法之详细攻略 目录 sublimetext的简介 sublimetext的安装 1、安装教程如下所示 sublimetext的使用方法 sublimetext的简介 Sublime Text 是一个文本编辑器&#xff08;收费软件&#xff0c;可以无限期试…

javascript基础十五:说说new操作符具体都干了什么?

一、是什么 在JavaScript中&#xff0c;new操作符用于创建一个给定构造函数的实例对象 举个粟子 function Parent (name,age){this.name name;this.age age; } undefined Parent.prototype.sayName function(){console.log(this.name) } ƒ (){console.log(this.name) } c…

佛朗斯冲击港交所IPO:叉车租赁的未来是数字化?

佛朗斯“三战”IPO。 图源&#xff1a;佛朗斯 近日&#xff0c;广州佛朗斯股份有限公司&#xff08;下文简称为“佛朗斯”&#xff09;正式向港交所递交招股书&#xff0c;拟于港交所主板挂牌上市。 值得注意的是&#xff0c;这并不是佛朗斯首次冲击IPO。2019年6月和2020年7月…

操作系统-计算机系统概述-特性发展分类分层结构

目录 一、定义 1.1特征 二、操作系统的分类和发展 2.1手工操作阶段 2.2批处理阶段 2.2.1单道批处理系统 2.2.2多道批处理系统 2.3分时操作系统 2.4实时操作系统 2.5 网络操作系统 2.6分布式操作系统 2.7 个人计算机操作系统 三、操作系统的运行与机制 内核态和用…

【Python】函数 ⑤ ( 函数说明文档 | 函数说明文档内容建议 | 代码示例 )

文章目录 一、函数说明文档1、函数说明文档简介2、函数说明文档内容建议2、代码示例 - 函数说明文档 一、函数说明文档 1、函数说明文档简介 函数说明文档 就是 通过 注释 对 函数的作用进行解释说明 ; 函数说明文档 用法 : 在 函数定义 后 , 函数体的第一行位置 , 输入六个双…

Linux:Linux基础网络设置

ifconfig ifconfig #查看网卡信息 inet---网络接口的ip地址 netmask---子网掩码 broadcast---广播地址 ether----物理地址&#xff08;mac地址&#xff09; hostname hostname #查看主机名 hostnamectl set-hostname 自定义主机名 route route # 查看网卡网关 destination-…

华为OD机试真题B卷 Java 实现【检查是否存在满足条件的数字组合】,附详细解题思路

一、题目描述 给定一个正整数数组&#xff0c;检查数组中是否存在满足规则的数字组合 规则&#xff1a;A B 2C 二、输入描述 第一行输出数组的元素个数。 接下来一行输出所有数组元素&#xff0c;用空格隔开。 三、输出描述 如果存在满足要求的数&#xff0c;在同一行…

Ubuntu使用ssh连接两个主机

前提&#xff1a;两者连接同一个WiFi&#xff08;局域网&#xff09; ssh安装&#xff1a; sudo apt-get install openssh-client sudo apt-get install openssh-server 首先在两个主机分别终端输入&#xff1a;ifconfig 查询两者的ip 用户名是前面的那个&#xff1a; …

【算法系列 | 1】深入解析排序算法之冒泡排序

序言 你只管努力&#xff0c;其他交给时间&#xff0c;时间会证明一切。 文章标记颜色说明&#xff1a; 黄色&#xff1a;重要标题红色&#xff1a;用来标记结论绿色&#xff1a;用来标记一级论点蓝色&#xff1a;用来标记二级论点 决定开一个算法专栏&#xff0c;希望能帮助大…

大湾区C++模拟题

大湾区信息学创新大赛模拟题 一、单项选择题&#xff08;15题共30分&#xff09; 1.计算机的运算速度取决于给定的时间内&#xff0c;它的处理器所能处理的数据量。处理器一次能处理的数据量叫字长。已知64位奔腾处理器一次能处理64个信息&#xff0c;相当于&#xff08; A …

厨电「前浪」压「后浪」

作者 | 辰纹 来源 | 洞见新研社 俗话说&#xff0c;姜是老的辣。说的是老年人有经验&#xff0c;办事稳重老练。 俗话也说&#xff0c;长江后浪推前浪。说的是经过历练的新人新事胜过旧人旧事。 这两句话看似矛盾&#xff0c;实则充满哲理&#xff0c;老而弥坚的老手与初生牛…

网关如何让非Matter设备快速加Matter网络?

作为连接智能家居设备的重要桥梁&#xff0c;网关是所有命令请求的入口&#xff0c;并完美充当起“翻译官”的角色。它能够精准“翻译”拥有不同通信协议、数据传输格式及网络地址里所包含的信息&#xff0c;将数据重新打包&#xff0c;以适应目的系统的需求。 虽然网关对于智…

matlab学习笔记(十)

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 matlab学习笔记&#xff08;十&#xff09; 一、实验目的二、实验原理和实验内容三、案例运行例1&#xff1a;电磁波传输问题的动态仿真&#xff0c;编写 MATLAB 程序实现线极…

Maven高级——分模块设计与开发

Maven的定义: 一个用来构建和管理java项目的工具。 分模块设计 一个大型项目通常需要有很多功能实现&#xff0c;这些功能分成多个模块&#xff0c;卸载一个项目里面最后只会导致这个项目越来越大。不便于维护&#xff0c;以及组件难以复用。 在项目设计的时候就可以将不同的…

九大亮点+六大好处,瑞云科技虚拟仿真实训平台引领教育信息化新潮流

随着新技术的快速发展和数字化转型的加速推进&#xff0c;高等教育面临着培养创新型、复合型、适应型人才的新要求。 虚拟仿真实训教学作为一种新型的教学模式&#xff0c;能够有效解决实训教学中的高投入、高损耗、高风险及难实施、难观摩、难再现的“三高三难”问题&#xf…

如何运行Python程序?

Python 是一种解释型的脚本编程语言&#xff0c;这样的编程语言一般支持两种代码运行方式&#xff1a; 1) 交互式编程 在命令行窗口中直接输入代码&#xff0c;按下回车键就可以运行代码&#xff0c;并立即看到输出结果&#xff1b;执行完一行代码&#xff0c;你还可以继续输…

手搓一个C++11的线程池(含测试)

实现 首先要有线程池这个结构体&#xff1a; 互斥锁条件变量消息队列关闭标志位 struct Pool {std::mutex mtx;std::condition_variable cond;std::queue<std::function<void()>> tasks;bool isClosed;//用来退出无限循环};【首先是线程池的对象】其实就是维护一…

【数据结构与算法】力扣:二叉树的前、中、后序遍历

递归法 前序遍历 给你二叉树的根节点 root &#xff0c;返回它节点值的前序 遍历。 示例 1&#xff1a; 输入&#xff1a;root [1,null,2,3] 输出&#xff1a;[1,2,3] 示例 2&#xff1a; 输入&#xff1a;root [] 输出&#xff1a;[] 示例 3&#xff1a; 输入&#xff1a;…

IPO后,北森驶向HR SaaS深水区

透过这次发布会&#xff0c;能感知到的依旧是北森马不停蹄的“加速度”&#xff0c;纪伟国口中不断重复的“以客户为中心”&#xff0c;以及不断开放兼容的生态。 作者| 皮爷 出品|产业家 北森&#xff0c;还是那个北森。 在刚刚举办的“HR SaaS未来势”2023北森春季产品…

Vscode搭建开发调试STM32环境IDE

单片机开发IDE环境如KeilMDK&#xff0c;虽然操作简单&#xff0c;方便调试。但就是代码编辑风格很老套&#xff0c;中文符号乱码还是常有的事。而如今流行的vscode编辑器很不错&#xff0c;免费且相当轻量级&#xff0c;用来代码开发体验很不错&#xff0c;看着都舒服。Clion …