【LeetCode】HOT 100(1)

news2025/1/19 20:43:46

题单介绍:

精选 100 道力扣(LeetCode)上最热门的题目,适合初识算法与数据结构的新手和想要在短时间内高效提升的人,熟练掌握这 100 道题,你就已经具备了在代码世界通行的基本能力。

目录

题单介绍:

题目:2. 两数相加 - 力扣(Leetcode)

题目的接口:

解题思路:

代码:

过过过过啦!!!!

题目:4. 寻找两个正序数组的中位数 - 力扣(Leetcode)

题目的接口:

解题思路:

代码:

过过过过啦!!!!

写在最后:


题目:2. 两数相加 - 力扣(Leetcode)

题目的接口:

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {

    }
};

解题思路:

这道题目其实不难啊,

所以我就直接上手做了,

导致代码其实写的不是很好啊,可以优化的地方不少,

不过整体思路是没有问题的,

这道题就是简单模拟加法进位,不过因为是在链表上实现,

所以对链表知识掌握有一定的要求,具体思路如下:

1. 建一个新链表

2. 计算进位并插入

3. 返回新链表的头结点

代码如下:

代码:

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
        ListNode* lt = new ListNode; //哨兵位的头结点
        ListNode* cur = lt; //遍历链表用的
        int up = 0; //进位
        while(l1 || l2) { //遍历完题目给的两个链表
            int sum = 0; //计算需要放入新链表的值
            if(l1) sum += l1->val;
            if(l2) sum += l2->val;
            sum += up;
            if(sum > 9) { //计算进位
                up = sum / 10 % 10;
                sum = sum % 10;
            } else up = 0; //如果不用进位就把上次的进位清空

            //这段操作是插入
            ListNode* newnode = new ListNode(sum);
            newnode->next = nullptr;
            cur->next = newnode;
            cur = cur->next;

            //遍历题目给的两个链表
            if(l1) l1 = l1->next;
            if(l2) l2 = l2->next;
        }
        if(up > 0) { //如果走完了,还有进位值,证明还需要再进一位,我就直接复用插入操作了
            ListNode* newnode = new ListNode(up);
            newnode->next = nullptr;
            cur->next = newnode;
            cur = cur->next;
        }

        //返回新链表的头结点
        return lt->next;
    }
};

过过过过啦!!!!

题目:4. 寻找两个正序数组的中位数 - 力扣(Leetcode)

题目的接口:

class Solution {
public:
    double findMedianSortedArrays(vector<int>& nums1, vector<int>& nums2) {

    }
};

解题思路:

这道题不简单啊,但是如果不考虑复杂度其实挺简单的,

我先把不考虑时间复杂的方法贴出来:

class Solution {
public:
    double findMedianSortedArrays(vector<int>& nums1, vector<int>& nums2) {
        vector<int> sum(nums1);
        for(auto e : nums2) sum.push_back(e); //合并数组
        sort(sum.begin(), sum.end()); //排序
        if(sum.size() % 2 != 0) { //分情况取中位数即可
            return sum[sum.size() / 2];
        }
        else {
            return ((double)sum[sum.size() / 2] + (double)sum[sum.size() / 2 - 1]) / 2; 
        }
        return 1;
    }
};

简单来讲就是合并数组,sort,然后取中位数即可。(实际上是能过的)

如果需要严格按照题目的时间复杂的求解的话,

那就只能使用二分法了。

我们可以将这题转换成用二分查找两个有序数组中第k个最小的数,

我们需要分多种情况考虑,代码如下:

代码:

class Solution {
public:
    double findMedianSortedArrays(vector<int>& nums1, vector<int>& nums2) {
        int size = nums1.size() + nums2.size();
        if(size % 2 == 1) { //奇数情况
            return find_mid_element(nums1, nums2, (size + 1) / 2);
        }
        else { //偶数情况
            return (find_mid_element(nums1, nums2, size / 2) 
                  + find_mid_element(nums1, nums2, size / 2 + 1)) / 2.0;
        }
    }
private: //查找中位数
    double find_mid_element(const vector<int>& nums1, const vector<int>& nums2, int k) {
        int m = nums1.size();
        int n = nums2.size();
        int i1 = 0, i2 = 0;
        while(true) { 
            if(i1 == m) { //当nums1数组被排除完
                return nums2[i2 + k - 1];
            }
            if(i2 == n) { //当nums2数组被排除完
                return nums1[i1 + k - 1];
            }
            if(k == 1) { //当k == 1的时候,证明找到了   
                return min(nums1[i1], nums2[i2]);
            }

            //避免出现越界的情况
            int new_i1 = min(i1 + k / 2 - 1, m - 1);
            int new_i2 = min(i2 + k / 2 - 1, n - 1);

            //更新k值,以及两个数组的区间
            if(nums1[new_i1] <= nums2[new_i2]) {
                k -= new_i1 - i1 + 1;
                i1 = new_i1 + 1;
            }
            else {
                k -= new_i2 - i2 + 1;
                i2 = new_i2 + 1;
            }
        }
    }
};

过过过过啦!!!!

写在最后:

以上就是本篇文章的内容了,感谢你的阅读。

如果感到有所收获的话可以给博主点一个哦。

如果文章内容有遗漏或者错误的地方欢迎私信博主或者在评论区指出~

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

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

相关文章

python基于Vue的web信息收集程序设计

本信息收集程序设计以Django作为框架&#xff0c;B/S模式以及MySql作为后台运行的数据库。本系统主要包括以下功能模块&#xff1a;个人中心、用户管理、上传信息管理、分类管理、分类归档管理等模块&#xff0c;通过这些模块的实现能够基本满足用户信息收集程序设计的操作。 好…

Dubbo源码解析一服务暴露与发现

Dubbo 服务暴露与发现 1. Spring中自定义Schema1.1 案例使用1.2 dubbo中的相关对象 2. 服务暴露机制2.1 术语解释2.2 流程机制2.3 源码分析2.3.1 导出入口2.3.2 导出服务到本地2.3.3 导出服务到远程(重点)2.3.4 开启Netty服务2.3.5 服务注册2.3.6 总结 3. 服务发现3.1 服务发现…

HCIP综合实验

实验拓扑 实验场景 内部PC网络通信设置&#xff1a;我们需要在公司内部PC的网络设置上配置VLAN&#xff08;虚拟局域网络&#xff09;&#xff0c;以实现相同VLAN下的PC之间可以自由通信。然而&#xff0c;为了保护客户信息和保障网络安全&#xff0c;我们要求在相同VLAN下的客…

2023年ChatGPT商业版免授权源码/AI绘画/付费系统

这里写自定义目录标题 欢迎使用Markdown编辑器新的改变功能快捷键合理的创建标题&#xff0c;有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants 创建一个自定义列表如何创建一个…

【Selenium】浏览器配置

通过selenium启动浏览器是&#xff0c;会发现是启动的一个新的浏览器&#xff0c;我们的一些登录信息&#xff0c;浏览器配置都会清楚&#xff0c;通过执行比较不方便&#xff0c;那么这一篇就简单介绍下如何配置Chrome浏览器的配置。 配置浏览器信息 在配置之前&#xff0c;首…

【Python]】地图热力图如何绘制?(含源代码)

文章目录 一、问题引入 & 使用地图的说明1.1 问题的引入1.2 使用地图的说明 二、方法1三、方法2 一、问题引入 & 使用地图的说明 1.1 问题的引入 我们有一个中国各省份的数据集&#xff0c;要求绘制地图热力图&#xff0c;该怎么实现呢&#xff1f; 部分数据集如下&…

23种设计模式之迭代器模式(Iterator Pattern)

前言&#xff1a;大家好&#xff0c;我是小威&#xff0c;24届毕业生&#xff0c;在一家满意的公司实习。本篇文章将23种设计模式中的迭代器模式&#xff0c;此篇文章为一天学习一个设计模式系列文章&#xff0c;后面会分享其他模式知识。 如果文章有什么需要改进的地方还请大佬…

今天公司来了个拿 30K 出来的测试,实在太牛了....

今天上班开早会就是新人见面仪式&#xff0c;听说来了个很厉害的大佬&#xff0c;年纪还不大&#xff0c;是离职过来的&#xff0c;薪资已经达到中高等水平&#xff0c;很多人都好奇不已&#xff0c;能拿到这个薪资应该人不简单&#xff0c;果然&#xff0c;自我介绍的时候都惊…

无惧面试,2023最新最全Java面试手册全网首次开放下载

最近感慨面试难的人越来越多了&#xff0c;一方面是市场环境&#xff0c;更重要的一方面是企业对Java的人才要求越来越高了。 ​基本上这样感慨的分为两类人&#xff0c;第一&#xff0c;虽然挂着3、5年经验&#xff0c;但肚子里货少&#xff0c;也没啥拿得出手的项目&#xff…

vue2介绍(入门)

目录 声明式渲染 v-bind v-if条件与循环 name命名 学会log打印 一些js方法 双向绑定v-model和v-bind 那么请实现一个复选框吧 自定义标签模板 声明式渲染 我感觉这里文档的意思是双向绑定&#xff0c; 或许需要清理一下js缓存机制 &#xff0c;嗯...不懂,响应式&…

视频理解学习笔记(三)

视频理解学习笔记&#xff08;三&#xff09; 时间梳理结果对比从hand-crafted到deep-learningDeepVideo论文概览 (Slow Fusion) Two-Stream and Its VariantsTwo-Stream CNN (Late Fusion)Beyond Short Snippets (Two-Stream LSTM/ConvPooling)3DConv 3DPool, Early Fusion …

Java学习路线(14)——Map集合类

一、介绍 概念 Map集合是一种双列集合&#xff0c;每个元素包含两个数据。元素格式&#xff1a;【keyvalue】键值对元素Map又称为 “键值对集合” Map集合格式&#xff1a; {key1value1,key2value2,key3value3,…} 二、Map集合的特点 Map家族图 1、说明&#xff1a; 使用…

期末复习总结【MySQL】库和表的基本操作 + 增删改查CURD

文章目录 前言一、数据库的基本操作1, 查看库2, 创建库3, 使用库4, 删除库 二、表的基本操作1, 创建表2, 查看表3, 查看表结构4, 删除表 三、增加(Create)四、查询(Retrieve) (重点)1, 全列查询2, 指定列查询3, 查询字段为表达式4, 指定别名5, 去重6, 排序7, 条件查询7.1, 基本…

Hbase操作

(1) 启动 启动顺序&#xff1a;Hadoop--zookeeper—hbase 主进程&#xff1a;HMaster 从进程&#xff1a;HRegionServer 确认进程是否正常 (2) 进入终端 [rootmaster ~]# hbase shell (3) 查看状态 命令&#xff1a;status 表示有3台机器&#xff0c;0台down掉&…

软件测试3年以为的躺平了,没想到还得内卷,这题太难了...

前段时间我同事&#xff08;做测试的一个妹子&#xff09;跟我讲&#xff0c;感觉早上起来十分的疲惫&#xff0c;不想上班&#xff0c;问我们这是什么样的现象&#xff0c;其实有时候我也有这种感觉&#xff0c;虽然我卷&#xff0c;但我也是肉体凡胎啊&#xff01;不是机器人…

Qt, Text Edit 和 Plain Text Edit关于调整字体样式的问题

问题: 在编写小案例的过程中需要使用一个文本容器用于显示文本效果, 因为涉及文本字体的 加粗, 倾斜, 下划线, 以及颜色效果, 这里使用了 Text Edit 组件, 但是使用后发现容器中的文本无法实现同时设置 加粗 倾斜 下划线的情况, 且单独设置时只有 下划线 有效果, 加粗 倾斜 均无…

C++模板(详解)

非类型模板参数 模板参数可分为类型形参和非类型形参。类型形参&#xff1a; 出现在模板参数列表中&#xff0c;跟在class或typename关键字之后的参数类型名称。非类型形参&#xff1a; 用一个常量作为类&#xff08;函数&#xff09;模板的一个参数&#xff0c;在类&#xff…

字节跳动测试岗面试挂在二面,我复盘总结了失败原因,决定再战一次

先说下我基本情况&#xff0c;本科不是计算机专业&#xff0c;现在是学通信&#xff0c;然后做图像处理&#xff0c;可能面试官看我不是科班出身没有问太多计算机相关的问题&#xff0c;因为第一次找工作&#xff0c;字节的游戏专场又是最早开始的&#xff0c;就投递了&#xf…

hystart++ 出炉

周三早上同事发我一个 rfc 9406 链接&#xff0c;microsoft hystart 标准化了&#xff0c;此前只是一个 draft。 说说我的看法。 信收敛不信测量&#xff0c;tcp 是端到端高熵体&#xff0c;对网络一无所知&#xff0c;过度信任测量则无法消除长尾&#xff0c;且可能劣化 p99…

Metasploit入门教程(非常详细)从零基础入门到精通,看完这一篇就够了!

通过本篇文章&#xff0c;我们将会学习以下内容&#xff1a; 1、在Windows上安装Metasploit 2、在Linux和MacOS上安装Metasploit 3、在Kali Linux中使用 Metasploit 4、升级Kali Linux 5、使用虚拟化软件构建渗透测试实验环境 6、配置SSH连接 7、使用SSH连接Kali 8、配…