菜鸡的原地踏步史08(◐‿◑)

技巧题

只出现一次的数字

class Solution {/** HashMap统计num和次数前面一天用堆魔怔了,也用堆进行排列...*/public int singleNumber(int[] nums) {PriorityQueue<int[]> pq = new PriorityQueue<>(new Comparator<int[]>() {public int compare(int[] o1, int[] o2) {return o1[1] - o2[1];}});HashMap<Integer, Integer> map = new HashMap<>();for(int num : nums) {map.put(num, map.getOrDefault(num, 0) + 1);}for(var node : map.entrySet()) {int[] temp = new int[2];temp[0] = node.getKey();temp[1] = node.getValue();pq.offer(temp);}return pq.peek()[0];}
}

多数元素

class Solution {/** HashMap统计?*/public int majorityElement(int[] nums) {int res = 0;int n = nums.length / 2;HashMap<Integer, Integer> map = new HashMap<>();for(int num: nums) {map.put(num, map.getOrDefault(num, 0) + 1);}for(var node: map.entrySet()) {if(node.getValue() > n) {res =  node.getKey();}}return res;}
}

颜色分类

class Solution {/** 使用堆不就秒了?*/public void sortColors(int[] nums) {PriorityQueue<Integer> pq = new PriorityQueue<>();for(int num : nums) {pq.offer(num);}int i = 0;while(!pq.isEmpty()) {nums[i] = pq.poll();i++;}}
}

芜湖~ 力扣200题打卡!

下一个排列

class Solution {/** i = 0 1 2 32 1 4 3 从后向前搜索2|1 3 4 搜到第一个i > i - 1的,记录i,排序i到末尾2|3 1 4 找到排序后第一个 > i - 1的,交换需要注意Arrays.sort(nums, i, j) 是左闭右开的区间对nums进行从i到末尾的sort需要(nums, i, len(而不是len - 1))*/public void nextPermutation(int[] nums) {int len = nums.length;for(int i = len - 1; i >= 0; i--) {if( i > 0 && nums[i] > nums[i - 1]) {Arrays.sort(nums, i, len);for(int j = i; j < len; j++) {if(nums[j] > nums[i - 1]) {int temp = nums[i - 1];nums[i - 1] = nums[j];nums[j] = temp;return;}}}else if(i == 0) {Arrays.sort(nums);} }}
}

寻找重复数

class Solution {/** hashmap直接秒了啊*/public int findDuplicate(int[] nums) {int res = 0;HashMap<Integer, Integer> map = new HashMap<>();for(int num: nums) {map.put(num, map.getOrDefault(num, 0) + 1);}for(var node: map.entrySet()) {if(node.getValue() > 1) {res = node.getKey();}}return res;}
}

图论

岛屿数量

class Solution {/** 深度优先搜索dfs类似和寻找字符串逐行逐列遍历判断*/public int numIslands(char[][] grid) {int row = grid.length;int col = grid[0].length;int island = 0;for(int i = 0; i < row; i++) {for(int j = 0; j < col; j++) {if(grid[i][j] == '1') {island++;dfs(grid, i, j);}}}return island;}public void dfs(char[][] grid, int i, int j) {int row = grid.length;int col = grid[0].length;if(i >= row || i < 0 || j >= col || j < 0 || grid[i][j] == '0') {return;}grid[i][j] = '0';dfs(grid, i + 1, j);dfs(grid, i, j + 1);dfs(grid, i - 1, j);dfs(grid, i, j - 1);}
}

腐烂的橘子

class Solution {/** 用2覆盖grid网格2表示初始化时间*/public int orangesRotting(int[][] grid) {if(grid == null || grid.length == 0) {return 0;}int row = grid.length;int col = grid[0].length;for(int i = 0; i < row; i++) {for(int j = 0; j < col; j++) {if(grid[i][j] == 2) {dfs(grid, i, j, 2);}}}int maxtime = 0;for(int i = 0; i < row; i++) {for(int j = 0; j < col; j++) {if(grid[i][j] == 1) {return -1;}else {maxtime = Math.max(maxtime, grid[i][j]);}}}return maxtime == 0 ? 0 : maxtime - 2;}public void dfs(int[][] grid, int i, int j, int time) {int row = grid.length;int col = grid[0].length;if(i >= row || i < 0 || j >= col || j < 0) {return;}if(grid[i][j] != 1 && grid[i][j] < time) { // 没新鲜橘子,且时间更少,倒回去return;}grid[i][j] = time;dfs(grid, i + 1, j, time + 1);dfs(grid, i, j + 1, time + 1);dfs(grid, i - 1, j, time + 1);dfs(grid, i, j - 1, time + 1);}
}

课程表


实现Trie 前缀树

class Trie {Map<Character, Map> map, t;public Trie() {map = new HashMap<>();}public void insert(String word) {t = map;for(char w: word.toCharArray()) {if(!t.containsKey(w)) {t.put(w, new HashMap<Character, Map>());}t = t.get(w);}t.put('#', null);}public boolean search(String word) {t = map;for(char w: word.toCharArray()) {if(!t.containsKey(w)) {return false;}t = t.get(w);}return t.containsKey('#');}public boolean startsWith(String prefix) {t = map;for(char w: prefix.toCharArray()) {if(!t.containsKey(w)) {return false;}t = t.get(w);}return true;}
}/*** Your Trie object will be instantiated and called as such:* Trie obj = new Trie();* obj.insert(word);* boolean param_2 = obj.search(word);* boolean param_3 = obj.startsWith(prefix);*/

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

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

相关文章

【人工智能】knn算法

目录 一、对[1.0,1.1],[1.0,1.0],[0,0],[0,0.1],[0.1,0.1],[1.1,1.1]六个点用knn进行聚类&#xff0c;并显示。 1. 未调用KNN算法前&#xff0c;绿色为未知分类 2. 调用KNN算法 3. 运行结果 二、使用knn算法分类手写数字文件 1. 第一个temp的含义 2. 第二个temp的含义 …

记录一次服务器一直向外发送大量请求(挖矿病毒)排除

1、症状 服务器一直向外发送SYN请求&#xff0c;并且无法通过netstat -anplt获取到对应的PID服务器CPU一直很低&#xff0c;通过PS查找不到异常程序安装NetHogs&#xff0c;工具卡死&#xff0c;无法显示是那个程序发起的请求&#xff08;因为请求都是SYN_SEND&#xff0c;并且…

【ARM】使用JasperGold和Cadence IFV科普

#工作记录# 原本希望使用CCI自带的验证脚本来验证修改过后的address map decoder&#xff0c;但是发现需要使用JasperGold或者Cadence家的IFV的工具&#xff0c;我们公司没有&#xff0c;只能搜搜资料做一下科普了解&#xff0c;希望以后能用到吧。这个虽然跟ARM没啥关系不过在…

基于神经网络的分类和预测

基于神经网络的分类和预测 一、基础知识&#xff08;一&#xff09;引言&#xff08;二&#xff09;神经网络的基本概念&#xff08;1&#xff09;神经网络&#xff08;2&#xff09;神经元&#xff08;3&#xff09;常用的激活函数&#xff08;非线性映射函数&#xff09;&…

【代码随想录算法训练营第六十六天|卡码网97.小明逛公园、127.骑士的攻击】

文章目录 97.小明逛公园127.骑士的攻击 97.小明逛公园 之前的题目都是只有一个出发点和到达点&#xff0c;这道题是有多个起始对&#xff0c;用之前的算法把每一对结果算出来也是可行的&#xff0c;在这里使用Floyd算法。 本质上是一种动态规划&#xff0c;dp数组dp[i][j][k]中…

webpack terser-webpack-plugin 不打包注释及log

踩坑记录&#xff1a;注意 terser-webpack-plugin": "^4.2.3" 对应着webpack4及版本一下的&#xff0c;5点多版本的对应webpack5&#xff0c;版本不对会报ERROR TypeError: Cannot read property javascript of undefined 1.安装三方包 npm install terser-web…

【Linux网络】IP协议{初识/报头/分片/网段划分/子网掩码/私网公网IP/认识网络世界/路由表}

文章目录 1.入门了解2.认识报头3.认识网段4.路由跳转相关指令路由 该文诸多理解参考文章&#xff1a;好文&#xff01; 1.入门了解 用户需求&#xff1a;将我的数据可靠的跨网络从A主机送到B主机 传输层TCP&#xff1a;由各种方法&#xff08;流量控制/超时重传/滑动窗口/拥塞…

RAG 召回提升相关方案分享

最近大半年时间都在做RAG的工作&#xff0c;分享一点个人探索的方向。和提升的方案。文章中会分享是如何做的&#xff0c;以及对应的效果。 核心问题 如何提升RAG的效果&#xff1f; 如何提升召回的准确率。 写在前边&#xff1a;已验证的方案 方案 优化方向 效果 备注 3.1…

iPad锁屏密码忘记怎么办?有什么方法可以解锁?

当我们在日常使用iPad时&#xff0c;偶尔可能会遇到忘记锁屏密码的尴尬情况。这时&#xff0c;不必过于担心&#xff0c;因为有多种方法可以帮助您解锁iPad。接下来&#xff0c;小编将为您详细介绍这些解决方案。 一、使用iCloud的“查找我的iPhone”功能 如果你曾经启用了“查…

07-7.5.3 处理冲突的方法

&#x1f44b; Hi, I’m Beast Cheng &#x1f440; I’m interested in photography, hiking, landscape… &#x1f331; I’m currently learning python, javascript, kotlin… &#x1f4eb; How to reach me --> 458290771qq.com 喜欢《数据结构》部分笔记的小伙伴可以…

Biz-Logger操作日志框架

文章目录 前言一、设计 / 对比 / 实现1.1 注解1.1.1 EnableBizLogger1.1.2 BizLogger1.1.3 BizLoggerComponent1.1.4 BizLoggerFunction 1.2 自定义函数1.2.1 IBizLoggerFunctionRegistrar1.2.2 AbstractBizLoggerFunctionResolver 1.3 日志上下文1.3.1 BizLoggerContext 1.4 S…

SSM学习6:Spring事务

简介 事务作用&#xff1a;在数据层保障一系列的数据库操作同成功同失败Spring事务作用&#xff1a;在数据层或业务层保障一系列的数据库操作同成功同失败 public interface PlatformTransactionManager{void commit(TransactionStatus status) throws TransactionStatus ;vo…

Elasticsearch 角色和权限管理

在大数据和云计算日益普及的今天&#xff0c;Elasticsearch 作为一款强大的开源搜索引擎和数据分析引擎&#xff0c;被广泛应用于日志分析、全文搜索、实时监控等领域。随着业务规模的扩大和数据敏感性的增加&#xff0c;对 Elasticsearch 的访问控制和权限管理也变得越来越重要…

【人工智能】Transformers Pipeline概述

欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;欢迎订阅相关专栏&#xff1a; 欢迎关注微信公众号&#xff1a;野老杂谈 V: LAF20151116 进行更多交流学习 ⭐️ 全网最全IT互联网公司面试宝典&#xff1a;收集整理全网各大IT互联网公司技术、项目、HR面试真…

【网络文明】关注网络安全

在这个数字化时代&#xff0c;互联网已成为我们生活中不可或缺的一部分&#xff0c;它极大地便利了我们的学习、工作、娱乐乃至日常生活。然而&#xff0c;随着网络空间的日益扩大&#xff0c;网络安全问题也日益凸显&#xff0c;成为了一个不可忽视的全球性挑战。认识到网络安…

Python数据分析案例52——基于SSA-LSTM的风速预测(麻雀优化)

案例背景 又要开始更新时间序列水论文的系列的方法了&#xff0c;前面基于各种不同神经网络层&#xff0c;还有注意力机制做了一些缝合模型。 其实论文里面用的多的可能是优化算法和模态分解&#xff0c;这两个我还没出专门的例子&#xff0c;这几天正好出一个优化算法的例子来…

uboot学习:(四)顶层makefile分析

目录 版本号 MAKEFLAGS变量 命令输出 静默输出 设置编译结果输出目录 代码检查&#xff08;一般不需要使用&#xff0c;了解就行&#xff09; 模块编译&#xff08;一般不用uboot编译模块&#xff0c;了解就行&#xff09; 获取主机架构和系统 设置目标架构、交叉编译…

隔离驱动-视频课笔记

目录 1、需要隔离的原因 1.2、四种常用的隔离方案 2、脉冲变压器隔离 2.1、脉冲变压器的工作原理 2.2、泄放电阻对开关电路的影响 2.3、本课小结 3、光耦隔离驱动 3.1、光耦隔离驱动原理 3.2、光耦隔离驱动的电源进行分析 3.3、本课小结 4、自举升压驱动 4.1…

JS【详解】对象(含对象的存储原理,对象的常用操作,判断对象是否为空对象,对象的深拷贝,对象的创建、遍历、合并、拷贝等)

简介 任何事物都可以看作一个对象&#xff0c;用属性描述它的特征&#xff0c;用方法描述它的行为&#xff0c;如下方代码所示&#xff1a; let obj {name: "朝阳",sayHi: function () {console.log("你好&#xff01;");}, }; typeOf obj // object变量…

大数据开发中的元数据:从基础到高级应用的全面指南

在大数据开发中&#xff0c;元数据&#xff08;Metadata&#xff09;是指描述数据的数据。元数据可以提供有关数据结构、数据类型、数据约束和数据关系的重要信息。合理利用元数据可以显著提高数据建模和管理的效率。本文将详细介绍如何根据元数据建表&#xff0c;并提供一些代…