【每日力扣】2007. 从双倍数组中还原原数组 与3. 无重复字符的最长子串

devtools/2024/10/22 7:41:31/

在这里插入图片描述

🔥 个人主页: 黑洞晓威
😀你不必等到非常厉害,才敢开始,你需要开始,才会变的非常厉害

2007. 从双倍数组中还原原数组

一个整数数组 original 可以转变成一个 双倍 数组 changed ,转变方式为将 original 中每个元素 值乘以 2 加入数组中,然后将所有元素 随机打乱

给你一个数组 changed ,如果 change双倍 数组,那么请你返回 original数组,否则请返回空数组。original 的元素可以以 任意 顺序返回。

示例 1:

输入:changed = [1,3,4,2,6,8]
输出:[1,3,4]
解释:一个可能的 original 数组为 [1,3,4] :
- 将 1 乘以 2 ,得到 1 * 2 = 2 。
- 将 3 乘以 2 ,得到 3 * 2 = 6 。
- 将 4 乘以 2 ,得到 4 * 2 = 8 。
其他可能的原数组方案为 [4,3,1] 或者 [3,1,4] 。

解题思路

首先把 changed\textit{changed}changed 排序,并且统计所有元素出现的频数。

然后我们从小到大依次遍历数组,如果对于一个元素,它的频数大于零,并且它的两倍数也还在数组中,我们则可以把它加入到答案中。

如果对于一个数找不到它两倍数,即两倍数的频数等于零,则说明无法找到原数组,返回空数组即可。

代码实现

class Solution {public int[] findOriginalArray(int[] changed) {Arrays.sort(changed);Map<Integer, Integer> count = new HashMap<>();for (int a : changed) {count.put(a, count.getOrDefault(a, 0) + 1);}int[] res = new int[changed.length / 2];int i = 0;for (int a : changed) {if (count.get(a) == 0) {continue;}count.put(a, count.get(a) - 1);if (count.getOrDefault(a * 2, 0) == 0) {return new int[0];}count.put(a * 2, count.get(a * 2) - 1);res[i++] = a;}return res;}
}

3. 无重复字符的最长子串

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

示例 1:

输入: s = "abcabcbb"
输出: 3 
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。

示例 2:

输入: s = "bbbbb"
输出: 1
解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。

示例 3:

输入: s = "pwwkew"
输出: 3
解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。

解题思路

  1. 初始化一个 HashMap 用于存储字符和字符的最新出现的位置。HashMap 的 key 存储字符,value 存储字符下标。
  2. 使用双指针 leftright 表示当前子串的左右边界,left 表示窗口的起始位置,right 是窗口的结束位置。
  3. 遍历整个字符串,对于字符串中的每个字符:
    • 如果字符已经在 HashMap 中,更新 left 指针的位置为该字符在 HashMap 中出现的位置加 1。
    • 更新该字符在 HashMap 中的位置为当前的位置。
    • 计算当前窗口的长度 right - left + 1 并更新最大长度 max
  4. 最终返回最大长度 max 即为最长的不含重复字符的子串长度。

代码实现

import java.util.HashMap;class Solution {public int lengthOfLongestSubstring(String s) {if (s.length() == 0) return 0;HashMap<Character, Integer> map = new HashMap<>();int max = 0;int left = 0;for (int right = 0; right < s.length(); right++) {if (map.containsKey(s.charAt(right))) {left = Math.max(left, map.get(s.charAt(right)) + 1);}map.put(s.charAt(right), right);max = Math.max(max, right - left + 1);}return max;}
}

http://www.ppmy.cn/devtools/6915.html

相关文章

数据赋能(58)——要求:数据赋能实施部门能力

“要求&#xff1a;数据赋能实施部门能力”是作为标准的参考内容编写的。 在实施数据赋能中&#xff0c;数据赋能实施部门的能力体现在多个方面&#xff0c;关键能力如下图所示。 在实施数据赋能的过程中&#xff0c;数据赋能实施部门应具备的关键能力如下。 理性思维与逻辑分…

iOS知识点---Runloop

iOS 中的 Runloop 机制是一种事件驱动模型&#xff0c;用于管理和调度线程上的事件&#xff0c;确保线程在有工作要做时保持活跃&#xff0c;无事可做时进入休眠状态以节省系统资源。以下是 Runloop 机制的关键组成部分及其工作原理&#xff1a; 关键组成部分与原理&#xff1…

深度学习--BP实战猫狗分类数据集

运用BP模型实现猫狗数据集的分类 数据集下载 首先&#xff0c;我们要先下载好要分类的数据集&#xff0c;下载网址如下&#xff1a; 猫狗大作战数据集下载 该数据集是Kaggle在2013年公开的猫狗数据集&#xff0c;该数据集总共25000张图片&#xff0c;猫狗各12500张。 部分…

区块链技术入门:基础、应用及未来展望

区块链技术&#xff0c;自比特币在2009年首次引入以来&#xff0c;已经迅速成为数字时代的一个重要技术。区块链不仅仅是加密货币的基础技术&#xff0c;其去中心化、透明、不可篡改的特点使其在多个领域显示出广泛的应用潜力。这里&#xff0c;我们将探讨区块链的基础知识、实…

docker方式 部署jenkins服务,实现持续集成(CI/CD)功能

一、背景&#xff1a; 因公司需求&#xff0c;需要部署一套jenkins自动化部署服务&#xff0c;并且是通过docker容器的方式部署的。 二、jenkins简介&#xff1a; 什么是Jenkins &#xff1f; Jenkins是一个开源软件&#xff0c;是基于Java开发的一种持续集成工具&#xff0c;用…

小记一篇 vuecli4项目 打包内存溢出问题

目录 背景先解决内存溢出问题 让项目能够打包打包优化公共第三方模块 提取出来 不走webpack 打包 , 改成 cdn 引入项目中使用 图片等 静态资源 全部走cdn使用thread-loader 开启多线程打包 后序 背景 其他项目组有个项目迭代了3年&#xff0c;突然有一天 vuecli-4 webpack打包…

webgl canvas系列——animation中基本旋转、平移、缩放(模拟冒泡排序过程)

文章目录 ⭐前言⭐canvas绘制图片&#x1f496;状态保存和恢复&#x1f496;移动、旋转、缩放、变形&#x1f496;移动绘制一个渐变的box&#x1f496;旋转&#x1f496;缩放 ⭐模拟冒泡排序过程⭐结束 ⭐前言 大家好&#xff0c;我是yma16&#xff0c;本文分享webgl canvas系…

C++ 几句话彻底点通虚表

#include <iostream>using namespace std;class Base { public:virtual void show() // 声明虚函数{cout << "Base" << endl;} };class Derived : public Base { public:void show() override // 覆盖虚函数{cout << "Derived" &l…