Leetcode刷题笔记11

415. 字符串相加

415. 字符串相加 - 力扣(LeetCode)

 解法一:头插

头插是指将一个新元素插入到链表的头部(即第一个位置)。

比如对于456和77,先计算两个数字的末项6+7的结果,然后往前挪动一位

头插的效率较低,每次在字符串的开头插入一个字符,所有后续的字符都需要向后移动一个位置,因此插入一个字符的时间复杂度为O(n),其中n是当前字符串的长度。如果有m个字符需要插入,整体时间复杂度为O(m * n)。在最坏情况下,当字符串长度为n,插入操作需要进行n次,总的时间复杂度为O(n^2)。

解法二:尾插

尾插是指将一个新元素插入到链表的尾部(即最后一个位置)。

尾插相较于头插来说,效率更高

在字符串的末尾追加一个字符的操作通常是O(1)时间复杂度,因为大多数情况下,这只需要将新字符添加到字符串的末尾。如果底层实现需要重新分配内存,这个操作可能会变慢,但这种情况的发生频率很低,均摊时间复杂度仍然为O(1)。如果有n个字符需要插入,总体时间复杂度为O(n)。

代码:C++

class Solution {
public:
    string addStrings(string num1, string num2) {
        int end1 = num1.size() - 1, end2 = num2.size() - 1;
        int next = 0; // 进位
        string strRet;
        while (end1 >= 0 || end2 >= 0) // 两个都结束了才结束,只要有一个大于等于0就继续
        {
            //int val1 = num1[end1]; // 直接取有可能会越界,比如end2还没结束,end1结束了,这时候访问就会越界
            int val1 = end1 >= 0 ? num1[end1] - '0' : 0; // 如果大于等于0,就给值,否则给0
            int val2 = end2 >= 0 ? num2[end2] - '0' : 0; // ASCII码值

            int ret = val1 + val2 + next;
            next = ret > 9 ? 1 : 0; // 大于9就进位1,不然进位0

            // 头插 -- 头插的效率很低
            // strRet.insert(0, 1, (ret%10) + '0'); // 0这个位置插入1个字符,比如字符0加3就变成字符3了
            // strRet.insert(strRet.begin(), (ret%10) + '0'); // 也可以给第一个位置的迭代器

            // 尾插效率高
            strRet += ('0' + ret % 10);

            --end1;
            --end2;
        }

        if (next == 1)
            strRet += '1';

        // 头插
        // if(next) // 比如9+1,如果还有一个1
        // {
        //     strRet.insert(strRet.begin(), '1');
        // }

        // 逆置
        reverse(strRet.begin(), strRet.end()); // 逆置区间必须是左闭右开[)


        return strRet;
    }
};

21.合并两个有序链表

21. 合并两个有序链表 - 力扣(LeetCode)

解法:递归

 先判断l1和l2的边界条件,然后直接使用递归。

比较list1list2当前节点的值:

  • 如果list1当前节点的值小于list2当前节点的值,将list1的下一个节点指向合并list1的下一个节点和list2的结果,返回list1
  • 否则,将list2的下一个节点指向合并list1list2的下一个节点的结果,返回list2

代码:C++

class Solution {
public:
    ListNode* mergeTwoLists(ListNode* list1, ListNode* list2) {
        // 1空返回2
        if(list1 == nullptr)
        {
            return list2;
        }
        // 2空返回1
        else if(list2 == nullptr)
        {
            return list1;
        }
        else if(list1->val < list2->val)
        {
            list1->next = mergeTwoLists(list1->next, list2);
            return list1;
        }
        else
        {
            list2->next = mergeTwoLists(list1, list2->next);
            return list2;
        }

    }
};

917. 仅仅反转字母

917. 仅仅反转字母 - 力扣(LeetCode)

解法:双指针

begin指向开头,end指向最后一个元素

begin遇到非字母字符就++,end遇到就--

当begin和end都指向字母时,交换它们指向的字符,然后分别移动begin向右,end向左。

代码:C++

class Solution {
public:
    bool IsLetter(char ch)
    {
        if((ch >= 'a' && ch <= 'z')
        || (ch >= 'A' && ch <= 'Z'))
        {
            return true;
        }
        else
        {
            return false;
        }
    }
    string reverseOnlyLetters(string s) {
        size_t begin = 0, end = s.size()-1;
        while(begin < end)
        {
            while(begin < end && !isalpha(s[begin])) // 也可以直接用c++里面的函数isalpha
            {
                // 不是字母就++
                ++begin;
            }
            while(begin < end && !isalpha(s[end]))
            {
                --end;
            }
            swap(s[begin], s[end]);
            ++begin;
            --end;
        }
        return s;
    }
};

387.字符串中的第一个唯一字符

387. 字符串中的第一个唯一字符 - 力扣(LeetCode)

解法:哈希表

可以直接使用一个数据模拟哈希表。

统计每个字母出现的次数,如果等于1就找到了。

因为是在循环中,所以是从前往后,找到就直接是第一个唯一字符。

代码:C++

class Solution {
public:
    int firstUniqChar(string s) {
        // 首先,创建一个数组存储
        int count[256] = {0}; 
        int n = s.size();
        // 统计每个字符出现的次数
        for(int i=0; i<n; ++i)
        {
            count[s[i]] += 1;
        }
        // 按照字符次序从前往后找只出现一次的字符
        for(int i=0; i<n; ++i)
        {
            if(count[s[i]] == 1)
            {
                return i;
            }
           
        }
    return -1;
    }
};

哈希表实现:

class Solution {
public:
    int firstUniqChar(string s) {
        unordered_map<int, int> frequency;
        for (char ch : s) {
            ++frequency[ch];
        }
        for (int i = 0; i < s.size(); ++i) {
            if (frequency[s[i]] == 1) {
                return i;
            }
        }
        return -1;
    }
};

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

基于PLC的全自动洗衣机控制系统课设

一、设计题目 1.1课题内容 根据设计参数和控制要求&#xff0c;设计一全自动洗衣机&#xff0c;画出其运行框图及梯形图控制程序的编制&#xff0c;并画出硬件接线图。 1.2设计参数 1.3控制要求 &#xff08;1&#xff09;按下启动按扭及水位选择开关&#xff0c;开始进水直…

18张Python数据科学速查表.png

数据科学已经发展成为一个庞大的系统&#xff0c;包含数学、统计学、概率论、计算机、数据库、编程等各种理论技术。 目前在主流的数据科学领域一般有三大生态&#xff0c;一是以sas、matlab、spss等为代表的商业软件生态&#xff0c;二是围绕R语言建立起来的开源生态&#xf…

CPN IDE实现分层效果

Shift键鼠标选中要分层的库所和变迁&#xff01;然后create subpage。 Subpage是这样的&#xff0c;不会像CPN tools里面自动生成IN和OUT库所&#xff0c;但是也能正确运行。 虽然父页面在运行中有标红&#xff1a;"port not defined" 错误通常意味着在模型中有一些连…

电脑提示d3dcompiler_47.dll丢失的解决方法,实测靠谱的5种方法

在计算机使用过程中&#xff0c;缺失d3dcompiler_47.dll这一系统文件是一个常见问题&#xff0c;尤其是对于游戏和图形密集型应用程序用户来说尤为重要。这个文件是DirectX软件工具包的一部分&#xff0c;主要用于处理图形渲染的应用程序接口的核心元素。当你在运行游戏或某些软…

连获殊荣,天润融通以AI技术重塑企业客户联络体验!

天润融通又获奖了。 2024年3月22日&#xff0c;「ToB行业头条」联合3W集团共同举办的「2024ToB头条行业大会」在北京举行。 为表彰在过去一年中表现卓越、对行业发展作出显著贡献的企业、产品和数字化转型案例&#xff0c;大会颁布了ToB年度榜单【2023中国ToB行业影响力价值榜…

【尝鲜】SpringCloudAlibaba AI 配置使用教程

1、环境配置 maven依赖pom.xml 注意配置远程仓库&#xff0c;原因见&#xff1a;Unresolved dependency: ‘org.springframework.ai:spring-ai-core:jar:0.8.1’ <dependencies><!--Base--><dependency><groupId>org.springframework.boot</group…

进化版ChatGPT的Siri今年无缘上线!苹果正打造史上最薄iPhone 17

目录 01 超强Siri助手预计2025年上线 02 集成ChatGPT但没有买单 03 iPhone 17更轻薄 最新报道称&#xff0c;苹果的AI功能将在未来几个月逐步推出&#xff0c;并持续到2025年。 据称&#xff0c;今年夏天结束前&#xff0c;开发者们仍无法试用和体验。 因此&#xff0c;在即…

【JavaEE】Spring Web MVC详解

一.基本概念. 什么是Spring Web MVC? 官方链接: https://docs.spring.io/spring-framework/reference/web/webmvc.html Spring Web MVC is the original web framework built on the Servlet API and has been included in the Spring Framework from the very beginning. Th…

Ubuntu22.04系统安装及配置

文章目录 一、选择“安装” 二、选择“语言” 三、安装器更新 四、键盘布局 五、选择安装类型 六、网络配置 七、代理设置 八、镜像地址 九、磁盘划分 十、设置用户名、主机名、登录密码 十一、升级到Ubuntu Pro 十二、SSH设置 十三、选装软件包 十四、开始安装进…

13.2 Go 接口的动态性

&#x1f49d;&#x1f49d;&#x1f49d;欢迎莅临我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」…

移动硬盘在苹果电脑上无法识别的诊断与恢复策略

一、问题描述 在数字时代&#xff0c;移动硬盘已成为我们存储和传输数据的重要工具。然而&#xff0c;当我们将移动硬盘插入苹果电脑时&#xff0c;有时会遇到无法识别的情况&#xff0c;这让我们感到十分困扰。本文将详细探讨移动硬盘插苹果电脑后读不出来的现象&#xff0c;…

超神级!Markdown最详细教程,程序员的福音

超神级&#xff01;Markdown最详细教程&#xff0c;程序员的福音Markdown最详细教程&#xff0c;关于Markdown的语法和使用就先讲到这里&#xff0c;如果喜欢&#xff0c;请关注“IT技术馆”。馆长会更新​最实用的技术&#xff01;https://mp.weixin.qq.com/s/fNzhLFyYRd3skG-…

经验分享,16进制与字符串的互相转换网站

分享一个16进制与字符串的互相转换的网站&#xff0c;比较实用。 网址&#xff1a; https://www.bejson.com/convert/ox2str/ 截图&#xff1a;

飞睿智能LR-WIFI无线数据采集模块,6公里视频图传,安防监控、工业传输数据更高效

在数字化浪潮席卷全球的今天&#xff0c;无线数据采集技术已经成为推动社会进步的重要力量。特别是在安防监控和工业领域&#xff0c;高效、稳定的数据传输成为了实现智能化、自动化的关键。飞睿智能LR-WiFi无线数据采集模块不仅具备可靠的传输性能&#xff0c;还能在复杂环境下…

LeetCode80. 删除有序数组中的重复项 II题解

LeetCode80. 删除有序数组中的重复项 II题解 题目链接&#xff1a; https://leetcode.cn/problems/remove-duplicates-from-sorted-array-ii/ 题目描述&#xff1a; 给你一个有序数组 nums &#xff0c;请你 原地 删除重复出现的元素&#xff0c;使得出现次数超过两次的元素…

UWA发布 | Unity手游性能年度蓝皮书

UWA本次发布的《2023-2024年度Unity手游性能蓝皮书》将汇总游戏行业使用Unity引擎进行手游开发过程中及游戏上线后的性能表现&#xff0c;从测试机型分布、引擎各模块开销、内存占用等方面剖析定位Unity手游性能瓶颈和趋势&#xff0c;反映了Unity手游行业的现状&#xff0c;帮…

Xtuner微调

环境安装 studio-conda xtuner0.1.17 conda activate xtuner0.1.17 进入家目录 &#xff08;~的意思是 “当前用户的home路径”&#xff09; cd ~ 创建版本文件夹并进入&#xff0c;以跟随本教程 mkdir -p /root/xtuner0117 && cd /root/xtuner0117 拉取 0.1.17 的版…

【课程系列05】某心科技AI大模型微调实战营-应用篇

网盘链接 链接: https://pan.baidu.com/s/1oARULXsXn8frkqq4ZKHBLA --来自百度网盘超级会员v6的分享 课程收获 课程内容涉及大模型的介绍、Transformer、Encoder、高级微调技术、Alpaca、AdaLoRA、QLoRA、Prefix Tuning和Quantization等主题 课程截图

CVE-2020-1957 漏洞复现

先声明一下&#xff0c;免杀还是会更的&#xff0c;不过中间可能会穿插一下渗透的内容&#xff01;&#xff01;&#xff01; 踩坑点&#xff1a; 在一开始翻阅了CSDN之后&#xff0c;发现不同文章之间存在出入&#xff0c;于是最后去了CVE的官方文档&#xff0c;和参考一些国…