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

【算法day2】无重复字符的最长子串 两数之和

无重复字符的最长子串

给定一个字符串 s ,请你找出其中不含有重复字符的 最长 子串 的长度。

在这里插入图片描述

https://leetcode.cn/problems/longest-substring-without-repeating-characters/

class Solution {
public:
    int lengthOfLongestSubstring(string s) {
        int sub_length = 0;
        vector<char> tmp = {};
        for (int i = 0; i < s.size(); i++) {
            bool find = false;
            int j = 0;
            for (; j < tmp.size(); j++) {
                if (tmp[j] == s[i]) {
                    find = true;
                    break;
                }
            }
            if (!find) {
                tmp.push_back(s[i]);
            } else {
                if (sub_length < tmp.size()) {
                    sub_length = tmp.size();
                }
                // 找到重复的了,只好删掉vector前面的那些
                for (int k = 0; k <= j; k++) {
                    tmp.erase(tmp.begin());
                }
                tmp.push_back(s[i]);
            }
        }
        if (sub_length < tmp.size()) {
            sub_length = tmp.size();
        }
        return sub_length;
    }
};

两数之和

在这里插入图片描述

https://leetcode.cn/problems/two-sum/description/
给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。

你可以假设每种输入只会对应一个答案,并且你不能使用两次相同的元素。

你可以按任意顺序返回答案。

class Solution {
public:
    vector<int> twoSum(vector<int>& nums, int target) {
        unordered_map<int,int> hashtable;
        for(int i=0;i<nums.size() ;i++){
            auto it = hashtable.find(target-nums[i]);
            if(it!=hashtable.end()){
                return {it->second,i};
            }
            hashtable[nums[i]] = i;
        }
        return {};
    }
};

http://www.kler.cn/a/574204.html

相关文章:

  • YOLOv8改进SPFF-LSKA大核可分离核注意力机制
  • linux上配置免密登录
  • react中的fiber和初次渲染
  • 爬虫逆向:脱壳工具Youpk的使用详解
  • rust笔记12:rust的泛型
  • 计网学习———网络安全
  • Uniapp使用wxml-to-canvas进行动态页面转图片
  • Better-SQLite3 参数绑定详解
  • 多模态模型在做选择题时,如何设置Prompt,如何精准定位我们需要的选项
  • 装饰器模式:灵活扩展对象功能的利器
  • 如何高效使用 Mybatis-Plus 的批量操作
  • CDH下配置Flume进行配置传输日志文件
  • 深入探究C++并发编程:信号 异步 原子
  • muduo库源码分析:TcpConnection 类
  • better-sqlite3之exec方法
  • 【深度学习】Adam(Adaptive Moment Estimation)优化算法
  • dify + ollama + deepseek-r1+ stable-diffusion 构建绘画智能体
  • 从零开始在Windows使用VMware虚拟机安装黑群晖7.2系统并实现远程访问
  • .keystore文件转成pkcs1.pem文件记录
  • 阿里云 DataWorks面试题集锦及参考答案