leetcode刷题(46-50)

news2024/11/24 23:47:46

算法是码农的基本功,也是各个大厂必考察的重点,让我们一起坚持写题吧。

遇事不决,可问春风,春风不语,即是本心。

我们在我们能力范围内,做好我们该做的事,然后相信一切都事最好的安排就可以啦,慢慢来,会很快,向前走,别回头。

目录

1.全排列

2.全排列II

3.旋转图像

4.字母异位词分组

5.Pow(x,n)


1.全排列

题目链接:. - 力扣(LeetCode). - 备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。icon-default.png?t=N7T8https://leetcode.cn/problems/permutations/description/

思路:该题的数组默认没有重复的,所以不需要考虑数字重复的问题。

方法1:标记回溯法,使用vis数组标记元素是否访问过,使用数字k标记访问了多少个元素,vis数组避免重复访问同一个元素,当访问的元素k等于数组的长度,则存入结果集合。

class Solution {
    public List<List<Integer>> permute(int[] nums) {
        List<List<Integer>> res = new ArrayList<>() ;
        List<Integer> tmp = new ArrayList<>() ;
        boolean [] vis = new boolean[nums.length] ;
        dfs(nums, 0, res, tmp, vis) ;
        return res ;
    }
    public void dfs(int [] nums, int k, List<List<Integer>> res, List<Integer> tmp, boolean [] vis){
        if(k == nums.length){
            res.add(new ArrayList<>(tmp)) ;
        }
        
        for(int i=0; i<nums.length; i++){
            if(vis[i]){
                continue ;
            }
            vis[i] = true ;
            tmp.add(nums[i]) ;
            //k标记有几个元素
            dfs(nums, k+1, res, tmp, vis) ;
            tmp.remove(k) ;
            vis[i] = false ;
        
        }
    }
}

方法2:交换法,每次全排列之前需要先交换元素,然后再进行全排列,全排列完成之后交换回来。

class Solution {
    public List<List<Integer>> permute(int[] nums) {
        List<List<Integer>> res = new ArrayList<>() ;
        List<Integer> tmp = new ArrayList<>() ;
        boolean [] vis = new boolean[nums.length] ;
        dfs(nums, 0, res, tmp) ;
        return res ;
    }
    public void dfs(int [] nums, int k, List<List<Integer>> res, List<Integer> tmp){
        if(k == nums.length){
            for(int i=0; i<nums.length; i++){
                tmp.add(nums[i]) ;
            }
            res.add(new ArrayList<>(tmp)) ;
            tmp.clear() ;
        }
        
        for(int i=k; i<nums.length; i++){
            swap(nums, i, k) ;
            dfs(nums, k+1, res, tmp) ;
            swap(nums,i,k) ;
        }
    }
    public void swap(int [] nums, int x, int y){
        int tmp = nums[x] ;
        nums[x] = nums[y] ;
        nums[y] = tmp ;
    }
}

2.全排列II

题目链接:. - 力扣(LeetCode). - 备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。icon-default.png?t=N7T8https://leetcode.cn/problems/permutations-ii/description/

思路:因为含有重复元素,首先需要对数组元素按照升序排序,然后使用标记回溯法,进行标记,除了访问过的元素不访问,也要避免元素的重复访问。

class Solution {
    public List<List<Integer>> permuteUnique(int[] nums) {
        List<List<Integer>> res = new ArrayList<>() ;
        List<Integer> tmp = new ArrayList<>() ;
        boolean [] vis = new boolean [nums.length] ;
        Arrays.sort(nums) ;
        dfs(nums,0,res,tmp,vis) ;
        return res ;
    }
    public void dfs(int [] nums, int k, List<List<Integer>> res, List<Integer> tmp, boolean [] vis){
        if(k == nums.length){
            res.add(new ArrayList<>(tmp)) ;
        }
        for(int i=0; i<nums.length; i++){
            if(vis[i] || (i>0 && vis[i-1] && nums[i-1]==nums[i])){
                continue ;
            }
            vis[i] = true ;
            tmp.add(nums[i]) ;
            dfs(nums, k+1, res, tmp, vis) ;
            tmp.remove(k) ;
            vis[i] = false ;
        }
    }
}

3.旋转图像

题目链接:. - 力扣(LeetCode). - 备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。icon-default.png?t=N7T8https://leetcode.cn/problems/rotate-image/description/

思路:

方法1:开辟一个新的二维数组来存储元素,当然题目要求不让使用这种方法。

class Solution {
    public void rotate(int[][] matrix) {
        int n = matrix.length;
        int [][] res = new int [n][n] ;
        for(int i=n-1; i>=0; i--){
            for(int j=0; j<n; j++){
                res[j][n-i-1] = matrix[i][j] ;
            }
        }
       for(int i=0; i<n; i++){
        for(int j=0; j<n; j++){
            matrix[i][j] = res[i][j] ;
        }
       }
    }
}

方法2:原地旋转数组,不需要额外的开辟存储空间,先水平翻转,然后沿着主对角线翻转。

class Solution {
    public void rotate(int[][] matrix) {
        int n = matrix.length;

        // 先水平翻转
        for(int i=0; i<n/2; i++){
            for(int j=0; j<n; j++){
                int tmp = matrix[i][j] ;
                matrix[i][j] = matrix[n-i-1][j] ;
                matrix[n-i-1][j] = tmp ;
            }
        }

        // 沿着主对角线翻转
        for(int i=0; i<n; i++){
            for(int j=0; j<i; j++){
                int tmp = matrix[i][j] ;
                matrix[i][j] = matrix[j][i] ;
                matrix[j][i] = tmp ;
            }
        }

    }
}

4.字母异位词分组

题目链接:. - 力扣(LeetCode). - 备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。icon-default.png?t=N7T8https://leetcode.cn/problems/group-anagrams/

思路:

class Solution {
    public List<List<String>> groupAnagrams(String[] strs) {
        List<List<String>> res = new ArrayList<>() ;
        Map<String, List<String>> map = new HashMap<String,List<String>>() ;
        for(int i=0; i<strs.length; i++){
            char [] c = strs[i].toCharArray() ;
            Arrays.sort(c) ;
            String str = new String(c) ;
            List<String> list = map.getOrDefault(str, new ArrayList<String>()) ;
            list.add(strs[i]) ;
            map.put(str, list) ;
        }
        for(List<String> values : map.values()){
            res.add(values) ;
        }
        return res ;
        
    }
}

5.Pow(x,n)

题目链接:. - 力扣(LeetCode). - 备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。icon-default.png?t=N7T8https://leetcode.cn/problems/powx-n/

思路:题解说是什么快速幂+递归/迭代,直接调api不香吗。

class Solution {
    public double myPow(double x, int n) {
        return Math.pow(x,n) ;
    }
}

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

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

相关文章

Vue发送http请求

1.创建项目 创建一个新的 Vue 2 项目非常简单。在终端中&#xff0c;进入您希望创建项目的目录(我的目录是D:\vue)&#xff0c;并运行以下命令&#xff1a; vue create vue_test 2.切换到项目目录&#xff0c;运行项目 运行成功后&#xff0c;你将会看到以下的编译成功的提示…

Oracle中递归查询(START WITH……CONNECT BY……)

一、基本语法 在Oracle中START WITH……CONNECT BY……一般用来查找存在父子关系的数据&#xff0c;也就是树形结构的数据。 SELECT * FROM TABLE WHERE 条件3 START WITH 条件1 CONNECT BY 条件2;start with [condition]&#xff1a;设置起点&#xff0c;用来限制第一层的数…

一文详解去噪扩散概率模型(DDPM)

节前&#xff0c;我们星球组织了一场算法岗技术&面试讨论会&#xff0c;邀请了一些互联网大厂朋友、参加社招和校招面试的同学。 针对算法岗技术趋势、大模型落地项目经验分享、新手如何入门算法岗、该如何准备、面试常考点分享等热门话题进行了深入的讨论。 合集&#x…

AI 克隆声音,只需 3 分钟(附最全教程)

作者&#xff1a;寒斜 继生成式文本大模型 Chatgpt&#xff0c;生成式图片 Stablediffusion 之后生成式语音 Text To Speech 在开源社区也出现了一匹黑马&#xff0c;就是 GPT-Sovits [ 1] 。 之所以说他是黑马&#xff0c;让人觉得惊艳&#xff0c;是因为在语音效果克隆上做…

Deformable-DETR

DETR表现出来的问题 训练周期很长&#xff0c;相比标准的one-stage/two-stage detection在COCO上 12 epochs就能出好的结果&#xff0c;DETR标配200 epochs.对小目标不友好 作者指出&#xff0c;DETR中Transformer的问题是&#xff0c;在初始化的时候&#xff0c;网络几乎是把…

浸没式液冷服务器的换热效率及节能潜力分析

服务器浸没式液冷的换热效率及节能潜力 摘要&#xff1a;我们针对服务器浸没式液冷实验台进行了深入测试&#xff0c;探究了不同室外温度和服务器发热功率对系统制冷PUE的影响。实验数据显示&#xff0c;该系统的制冷PUE值介于1.05至1.28之间&#xff0c;高效节能特点显著。 在…

在哪可以查到全网的司法诉讼信息?

司法涉诉信息指的是再司法活动中形成的各种记录和资料&#xff0c;涵盖了诉讼案件的立案&#xff0c;审判&#xff0c;执行等各个环节的记录和文件。比如基本案件信息&#xff0c;开庭信息&#xff0c;审判信息&#xff0c;执行信息等。有时候还会涉及到被执行人&#xff0c;司…

创建进程的常用方式

自学python如何成为大佬(目录):https://blog.csdn.net/weixin_67859959/article/details/139049996?spm1001.2014.3001.5501 在Python中有多个模块可以创建进程&#xff0c;比较常用的有os.fork()函数、multiprocessing模块和Pool进程池。由于os.fork()函数只适用于Unix/Linu…

常见的创建型设计模式( 一 )

设计模式( 一 ) 常见的创建型设计模式 1.单例模式 : 确保一个类只有一个实例 , 为整个程序提供一个全局的访问接口。getInstance 实现方式 饿汉式&#xff0c;在调用getInstance 创建实例的时候 &#xff0c;实例已经存在了 &#xff0c;不需要我们再次去 new创建。 优点&a…

Pytorch编写Transformer

本文参考自https://github.com/datawhalechina/learn-nlp-with-transformers/blob/main/docs/ 在学习了图解Transformer以后&#xff0c;需要用Pytorch编写Transformer&#xff0c;下面是写代码的过程中的总结&#xff0c;结构根据图解Transformer进行说明。 import numpy as …

stable diffusion 局部重绘 reference-only api 接口调试

webUI api payload 插件生成的接口参数不准确&#xff0c;reference-only 的image不是对象&#xff0c;就是不同字符串字段&#xff0c;直接传&#xff0c;不是套image。 综上&#xff0c;那个插件参数不确定&#xff0c;应直接看插件的源码&#xff0c;看它接受什么参数 错误…

校园车辆管理系统的设计与实现

第1章 绪论 1.1 研究背景与意义 随着高等教育的普及和扩张&#xff0c;大学校园已成为一个综合性的小型社会。教学楼、实验室、宿舍、体育设施等构成了庞大且复杂的校园基础设施。在这样的环境下&#xff0c;教师、学生、家长及访客的车辆数量也随之增多&#xff0c;这不仅带来…

UI设计师是不是青春饭?你摆烂,啥工作都是青春饭!

一、UI设计师的岗位职责包括&#xff1a; 用户研究和需求分析&#xff1a;了解用户需求、行为和偏好&#xff0c;进行用户调研和用户体验测试&#xff0c;以便设计出符合用户期望的界面。制定设计方案&#xff1a;根据用户需求和产品定位&#xff0c;制定UI设计方案&#xff0c…

[手机Linux PostmarketOS]一,1加6T真正的手机Linux系统

前面用Linux deploy软件安装了Linux系统在手机&#xff0c;实则不是真正的手机刷成了linux系统&#xff0c;而是通过Linux deploy软件在容器里安装了Linux系统&#xff0c;在使用方面会有诸多限制&#xff0c;并不能发挥Linux的真实强大之处&#xff0c;于是我又百度又谷歌(真不…

标准化的力量:如何通过PDM提升企业研发效率

在当今竞争激烈的市场环境中&#xff0c;企业必须不断优化其产品开发流程以保持竞争力。PDM产品数据管理系统与企业标准化的结合&#xff0c;为企业提供了一种有效的方法来管理和优化其研发流程。本文将探讨PDM与企业标准化的概念&#xff0c;它们在企业中的相互作用&#xff0…

上市公司-社会责任报告、ESG报告文本(2006-2023年)

上市公司社会责任报告是企业对外公布的一份关于其社会责任实践和成果的详细文件&#xff0c;涵盖环境保护、社会贡献和公司治理等方面的表现。通常包含公司在减少环境影响、提升社会福祉、维护员工权益、促进社区发展以及确保透明和道德的管理实践等方面的信息和数据。有助于了…

基于Pytorch框架的深度学习Swin-Transformer神经网络食物分类系统源码

第一步&#xff1a;准备数据 5种鸟类数据&#xff1a;self.class_indict ["苹果派", "猪小排", "果仁蜜饼", "生牛肉薄片", "鞑靼牛肉"] &#xff0c;总共有5000张图片&#xff0c;每个文件夹单独放一种数据 第二步&…

PS系统教程23

减淡加深海绵工具 减淡工具 作用&#xff1a;提炼物体颜色 加深工具 作用&#xff1a;变暗物体颜色&#xff0c;加深物体深度 海绵工具 作用&#xff1a;修正物体饱和度&#xff0c;加大纯度 减淡工具 老套路&#xff0c;找一个图片 复制新建粘贴Ctrl键J复制图层选择减…

WinRAR应用文件图标是白色怎么解决

1.打开程序-选项-设置 2.找到集成-选择全部切换&#xff0c;保存即可。

找不到concrt140.dll无法继续执行代码的几种解决方法

在数字时代&#xff0c;电脑用户经常会遇到各种技术问题&#xff0c;其中DLL文件缺失是最常见的问题之一。今天&#xff0c;我们将重点介绍CONCRT140.DLL文件的重要性&#xff0c;以及当它丢失时对电脑的影响。同时&#xff0c;我们提供了五种解决方法和预防措施&#xff0c;帮…