双非二本找工作前的准备day23

 学习目标:

每天复习代码随想录上的题目1-2道算法(时间充足可以继续)

今日碎碎念:

1)滴滴开了暑期实习。

2)今天开始是回溯篇,然后是贪心以及dp,保持打卡!加油啦!

3)今天要做的事情就是,完成算法打卡,然后总结实习的工作,整理好自己的思路,应对后面可能的面试。


力扣刷题

算法

力扣77:77. 组合

未剪枝优化

class Solution {
    List<List<Integer>> res;
    List<Integer> list;
    public List<List<Integer>> combine(int n, int k) {
        res = new ArrayList<>();
        list = new ArrayList<>();
        back(n,k,1);
        return res;
    }
    public void back(int n,int k,int startIndex){
        //对于回溯最重要的就是确定终止条件
        if(list.size() == k){
            //如果小结果集里面的个数为k,就表示要回溯了
            res.add(new ArrayList<Integer>(list));
            return;
        }
        //如果没满k,就得继续加元素到小结果集里面
        for(int i = startIndex;i<=n;i++){
            list.add(i);
            //进入下一轮选择
            back(n,k,i+1);
            //要把添加进去的末尾元素去除
            list.remove(list.size()-1);
        }
    }
}

剪枝优化

解答思路:

        1)当我们继续去找元素的时候有个隐性条件,就是我们最终的小结果集的数量一定得满足k,如果我剩下的数量无法满足k,那就没必要往后找了

        2)比如,n=4,k=4的情况下,不难想出我们的小结果集只有1234这一种情况,而不可能会出现234这种情况。那么当我挑出来了1234这种情况的时候,判断后续数量很明显长度最大为3,不满足k,因此没必要继续遍历

class Solution {
    List<List<Integer>> res;
    List<Integer> list;
    public List<List<Integer>> combine(int n, int k) {
        res = new ArrayList<>();
        list = new ArrayList<>();
        back(n,k,1);
        return res;
    }
    public void back(int n,int k,int startIndex){
        //对于回溯最重要的就是确定终止条件
        if(list.size() == k){
            //如果小结果集里面的个数为k,就表示要回溯了
            res.add(new ArrayList<Integer>(list));
            return;
        }
        //如果没满k,就得继续加元素到小结果集里面
        //剪枝说明:如果剩下的数量不足以组成我要求的list了,就没必要往后走了
        for(int i = startIndex;i<=n-(k-list.size())+1;i++){
            list.add(i);
            //进入下一轮选择
            back(n,k,i+1);
            //要把添加进去的末尾元素去除
            list.remove(list.size()-1);
        }
    }
}


力扣216:216. 组合总和 III

解答思路:

        1)与上道题思路是类似的,多了剪枝判断而已

class Solution {
    List<List<Integer>> res;
    List<Integer> list;
    public List<List<Integer>> combinationSum3(int k, int n) {
        res = new ArrayList<>();
        list = new ArrayList<>();
        back(k,n,1,0);
        return res;
    }
    public void back(int k,int n,int index,int sum){
        //剪枝:如果当前和已经大于n,说明不需要往后走了,因为题目给定的集合是有序的
        if(sum > n) return;
        //终止条件:小结果集为k就退出,如果sum为n就加入结果集
        if(list.size() == k){
            if(sum == n) res.add(new ArrayList<>(list));
            return;
        }
        //开始回溯以及剪枝。剪枝同77题,后面的元素不足以满足数量就不需要继续遍历了
        for(int i = index;i<=9-(k-list.size())+1;i++){
            list.add(i);
            //计算当前总和
            sum+=i;
            back(k,n,i+1,sum);
            //回溯
            list.remove(list.size()-1);
            sum-=i;
        }
    }
}

力扣17:17. 电话号码的字母组合

解答思路:看注释即可

class Solution {
    //设置全局列表存储最后的结果
    List<String> list = new ArrayList<>();
    public List<String> letterCombinations(String digits) {
        if (digits == null || digits.length() == 0) {
            return list;
        }
        //初始对应所有的数字,为了直接对应2-9,新增了两个无效的字符串""
        String[] numString = {"", "", "abc", "def", "ghi", "jkl", "mno", "pqrs", "tuv", "wxyz"};
        back(digits,numString,0);
        return list;
    }
    //大量拼接用StringBuilder
    StringBuilder sb = new StringBuilder();
    public void back(String digits,String[] numString,int index){
        //终止条件:index是记录从digits里面选取第几个元素
        if(index == digits.length()){
            list.add(sb.toString());
            return;
        }
        //取出当前按下的数字代表的字符串
        String str = numString[digits.charAt(index)-'0'];
        for(int i = 0;i<str.length();i++){
            sb.append(str.charAt(i));
            back(digits,numString,index+1);
            sb.deleteCharAt(sb.length()-1);
        }
    }
}

 力扣39:39. 组合总和

解答思路:看注释即可

class Solution {
        List<List<Integer>> res;//大结果集
        List<Integer> list;//小结果集
    public List<List<Integer>> combinationSum(int[] candidates, int target) {
        res = new ArrayList<>();
        list = new ArrayList<>();
        //因为原数组是没有排序的,先对原数组进行排序
        Arrays.sort(candidates);
        back(candidates,target,0,0);
        return res;
    }
    //参数:数组,目标和,当前和,当前位置(下标)
    public void back(int[] candidates,int target,int sum,int index){
        //终止条件: sum == target
        if(sum == target){
            //将小结果集加入大结果集
            res.add(new ArrayList<>(list));
            return;
        }
        //因为每个数字可以无限制重复被选取,所以index得传入i
        for(int i = index;i<candidates.length;i++){
            if(sum+candidates[i] > target) break;
            list.add(candidates[i]);
            back(candidates,target,sum+candidates[i],i);
            list.remove(list.size()-1);
        }
    }
}

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

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

相关文章

读书笔记——《高质量C++/C编程指南》(2)

目录 前言 命名规则 共性规则 简单的Windows应用程序命名规则 表达式和基本语句 运算符优先级 复合表达式 if语句 布尔变量与零值比较 整型变量与零值比较 浮点变量与零值比较 指针变量与零值比较 对if 语句的补充说明 循环语句的效率 for 语句的循环控制变量 s…

数据库大作业——基于qt开发的图书管理系统(四)项目目录的整理与绘制登录页面

项目目录的管理 前言 在上几篇的文章里面我们完成了基本环境的搭建,整理了项目数据库表结构并且成功的手动的加载了Qt的mysql数据库驱动&#xff0c;现在就要开始完成项目准备工作的最后一步:构建项目目录,一个好的项目离不开一个好的代码组织结构,所以在开始动手写我们这个项…

Java | Leetcode Java题解之第70题爬楼梯

题目&#xff1a; 题解&#xff1a; public class Solution {public int climbStairs(int n) {double sqrt5 Math.sqrt(5);double fibn Math.pow((1 sqrt5) / 2, n 1) - Math.pow((1 - sqrt5) / 2, n 1);return (int) Math.round(fibn / sqrt5);} }

无人机+通信中继:短波电台技术详解

随着无线通信技术的不断发展&#xff0c;无人机作为一种新型的信息传输平台&#xff0c;已经在多个领域得到了广泛应用。其中&#xff0c;无人机与短波电台的结合&#xff0c;为通信中继领域带来了全新的可能性。本文将详细解析无人机在通信中继中的应用&#xff0c;以及短波电…

产品专访|“产品”远程运维系统与“设备”远程运维系统的区别?

在日益复杂的工业制造环境下&#xff0c;远程运维已经成为生产制造企业不可或缺的一部分。在这个大背景下&#xff0c;产品远程运维系统和设备远程运维系统的需求越来越多&#xff0c;各自发挥着独特的作用。然而&#xff0c;尽管它们都涉及到远程运维的概念&#xff0c;但在实…

Nest.js中使用任务调度

java中的xxl在nestJs中是有内置的任务调度nestjs/schedule npm install --save nestjs/schedule 在model中引入使用 在service中直接使用就行 具体间隔多久看官方配置 Task Scheduling | NestJS 中文文档 | NestJS 中文网

STM32F1#1(入门了解)

一、STM32开发平台和工具 1.1 STM32芯片介绍 典型微控制器由CPU&#xff08;运算器、控制器&#xff09;、RAM、ROM和输入输出组成。 1.2 STM32核心板 STM32核心板配件&#xff1a; ①JTAG/SWD仿真-下载器 ②通信-下载模块 ③OLED显示屏 1&#xff09; 通信-下载模…

智慧工厂管理系统

随着科技的飞速发展&#xff0c;传统工厂正经历着一场前所未有的变革。在这个以智能化、信息化为主导的新时代&#xff0c;HiWoo Cloud平台以其卓越的智慧工厂管理系统&#xff0c;成为了众多企业转型升级的首选工具。今天&#xff0c;就让我们一起走进HiWoo Cloud的世界&#…

FTTR(光猫)ITMS注册NCE纳管

ITMS注册 TR069交互过程&#xff1a; 1.1. TR069交互—主动连接机制 主动连接机制是指CPE主动发出请求连接事件(事件可以为&#xff1a; 0 BOOTSTRAP&#xff1b; 1 BOOT; PERIODIC等等)给ACS。在连接建立之后才能进行业务处理(通过调用RPC方法实现)。 备注&#xff1a;政企…

【2024最新华为OD-C卷试题汇总】字符串分割(100分) - 三语言AC题解(Python/Java/Cpp)

&#x1f36d; 大家好这里是清隆学长 &#xff0c;一枚热爱算法的程序员 ✨ 本系列打算持续跟新华为OD-C卷的三语言AC题解 &#x1f4bb; ACM银牌&#x1f948;| 多次AK大厂笔试 &#xff5c; 编程一对一辅导 &#x1f44f; 感谢大家的订阅➕ 和 喜欢&#x1f497; 文章目录 前…

2024.5.8

聊天框完善 #include "mywidget.h" #include "ui_mywidget.h"MyWidget::MyWidget(QWidget *parent): QWidget(parent), ui(new Ui::MyWidget) {ui->setupUi(this);//设置窗口大小this->resize(400,560);//设置窗口图标和标题this->setWindowTit…

快过VS Code,10天暴增20k star,高性能多人协作IDE横空出世

道歉 其实不意味着道歉的人错了 而是他认为这段关系 比自己的尊严更重要 失败了 不是说你有多差 而是说 你需要更努力了 写代码最重要的一个选择就是选哪个IDE了&#xff0c;目前主流的选择是vscode和IDEA了。 但是vscode虽然轻量&#xff0c;但是对于大型的项目仍然显得…

C语言----杨辉三角

各位看官们好。学习到这里想必大家应该对C语言的了解也是很深刻的了吧。但是我们也不能忘记我们一起学习的知识啊。在我们以前学习C语言的时候我想大家应该都听说过杨辉三角吧。虽然我们把其中的规律找到那么这个代码就简单很多了。那么接下里我们就来讲讲杨辉三角。 首先我们先…

实战28套JAVA高端架构P6/P7/P8架构—全栈架构

概述 Java SE Java SE&#xff08;Java Platform&#xff0c;Standard Edition&#xff09;。Java SE 以前称为J2SE。它允许开发和部署在桌面、服务器、嵌入式环境和实时环境中使用的Java应用程序。Java SE 包含了支持Java Web 服务开发的类&#xff0c;并为Java Platform&…

Web服务器和Tomcat

Web介绍 对于http协议操作进行封装、简化web程序开发 部署web项目&#xff0c;对外提供上网信息浏览 Tomcat介绍 一个轻量级的web服务器 也称为web容器 Tomcat的文件夹介绍 下载地址&#xff1a;Apache Tomcat - Apache Tomcat 9 Software Downloads 安装&#xff1a;直…

「YashanDB迁移体验官」Oracle向YashanDB迁移的丝滑体验

&#x1f4e2;&#x1f4e2;&#x1f4e2;&#x1f4e3;&#x1f4e3;&#x1f4e3; 作者&#xff1a;IT邦德 中国DBA联盟(ACDU)成员&#xff0c;10余年DBA工作经验&#xff0c; Oracle、PostgreSQL ACE CSDN博客专家及B站知名UP主&#xff0c;全网粉丝10万 擅长主流Oracle、My…

【数据可视化-01】Matplotlib图形实战宝典

在数据分析领域&#xff0c;图形化展示数据是非常重要的环节。Python中的matplotlib库是绘制各类图形的强大工具。本文将介绍如何使用matplotlib绘制折线图、直方图、饼图、散点图和柱状图等数据分析中常见的图形&#xff0c;并附上相应的代码示例&#xff0c;可以当初matplotl…

GD32F103RCT6/GD32F303RCT6(9)高级定时器互补PWM波输出实验

本文章基于兆易创新GD32 MCU所提供的2.2.4版本库函数开发 后续项目主要在下面该专栏中发布&#xff1a; 手把手教你嵌入式国产化_不及你的温柔的博客-CSDN博客 感兴趣的点个关注收藏一下吧! 电机驱动开发可以跳转&#xff1a; 手把手教你嵌入式国产化-实战项目-无刷电机驱动&am…

第 8 章 电机测速(自学二刷笔记)

重要参考&#xff1a; 课程链接:https://www.bilibili.com/video/BV1Ci4y1L7ZZ 讲义链接:Introduction Autolabor-ROS机器人入门课程《ROS理论与实践》零基础教程 8.3.3 电机测速01_理论 测速实现是调速实现的前提&#xff0c;本节主要介绍AB相增量式编码器测速原理。 1.概…

深度学习——前馈全连接神经网络

前馈全连接神经网络 1.导入需要的工具包2.数据导入与数据观察&#xff08;1&#xff09;读取csv的文件信息&#xff1a;&#xff08;2&#xff09;训练数据前5行&#xff08;3&#xff09;打印第一个图&#xff08;4&#xff09;观察数据中的信息&#xff08;5&#xff09;查看…
最新文章