算法汇总啊

news2025/1/21 0:59:22

一些常用算法汇总

  • 算法思想-----数据结构
  • 动态规划(DP)
    • 0.题目特点
    • 1.【重点】经典例题(简单一维dp)
      • 1.斐波那契数列
      • 2.矩形覆盖
      • 3.跳台阶
      • 4.变态跳台阶
    • 2.我的日常练习汇总(DP)
      • 1.蓝桥真题-----路径

算法思想-----数据结构

  • 数据结构的存储方式 : 顺序存储(数组) , 链式存储(链表)

      顺序存储(数组) : 在内存中的存储空间是连续的 , 所以可以通过索引来获取存储的元素
      链式存储(链表) : 不是连续存储的 , 可能是这一个那一个的 .
      				 通常是由 数据域和指针域组成-->也就是data和next指针 (next指针指向下一个节点的地址)
    
  • 数据结构底层逻辑

      所以啊 , 数据结构的那些东西(数组,链表,栈,队列,图,树,散列表等等)--->其实底层逻辑 都是数组或链表
    
  • 数组和链表优缺点

    数组--->可以随机访问(通过索引) , 但是 需要考虑存储容量的问题
    链表--->没有存储容量的问题 , 但是不能随机访问元素
    
  • 数据结构存在的意义

      数据结构存在的意义---->就是为了处理数据啊(增删改查)--->怎么增删改查呢?---->遍历+递归
      那为什么会有那么多种数据结构呢 ? ---->因为每种数据结构的应用场景不一样(灵活应用,优化代码嘛) 
    

动态规划(DP)

0.题目特点

  • 1.计数(问:how many ways。。。)
    • a.有多少种方式 走到右下角
    • b.有多少种方法 选出k个数使得和是sum
  • 2.求最大值、最小值(最大的一个解题类型)
    • a.从左上角走到右下角 路径的最大数字和
    • b.最长上升子序列的长度
  • 3.求存在性
    • a.取石子游戏,先手是否必胜
    • b.能不能选出k个数 使得和是sum

1.【重点】经典例题(简单一维dp)

1.斐波那契数列

1 1 2 3 5 8 …

这是最经典的递归问题,
但 如果用递归求解,会重复计算一些子问题。
那如何用 动态规划 求解呢。

题目描述:求斐波那契数列的第n项,n<39。
在这里插入图片描述

  • 递归法
    根据递推公式:f(n) = f(n-1)+f(n-2)
int fib(int n){
	if(n<2) return n;
	return fib(n-1)+fib(n-2);
}
  • dp
    • 1.状态 : 最后一步是求f[n]
    • 2.转移方程:f[n] = f[n-1]+f[n-2]
    • 3.初始化:f[1]=1 ;边界条件:n<=1
    • 4.计算顺序:1—>n
public int Fibonacci(int n){
	if(n <= 1) return n;	//边界条件
	int[] fib = new int[n+1];
	fib[1] = 1;		//初始化
	fib[2] = 1;
	for(int i=2;i<=n;i++){	//计算顺序
		 fib[i] = fib[i-1] + fib[n-2];	//状态方程
	return fib[n];
}

2.矩形覆盖

题目描述:我们可以用2*1的小矩形横着或竖着去覆盖更大的矩形。请问用n2*1的小矩形无重叠的覆盖一个2*n的大矩形,总共有多少种方法?

  • 分析:dp[1] = 1 ; dp[2] = 2

      要覆盖2*n的大矩形,
      可以先覆盖一个2*1的矩形,再覆盖2*(n-1)的矩形;
      也可以先覆盖两个个2*2的矩形,再覆盖2*(n-2)的矩形。
      而覆盖2*(n-1)和2*(n-2) 可以看做是子问题,传递下去
    

在这里插入图片描述

- 最后一步:求 dp[n]
- 初始化:dp[1] = 1 ; dp[2] = 2;  边界条件:n<=2
- 转移方程(递归表达式):dp[n] = dp[n-1] + dp[n-2]
- 计算顺序:1-->n
  • 递归法
public int rectCover(int n){
	if(n<=2) return n;
	return rectCover(n-1)+rectCover(n-2);
}
  • dp算法
public int rectCover(int n){
	if(n<=2) return n;
	int[] dp = new int[n+1];
	dp[1] = 1;
	dp[2] = 2;
	for(int i=3;i<=n;i++){
		dp[i] = dp[i-1]+dp[i-2];
	}
	return dp[n];
}

3.跳台阶

题目描述:一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级台阶总共有多少种跳法。
在这里插入图片描述

  • 分析

      int[] dp = new int[n]; //dp[i]表示跳到第i级台阶有多少种跳法
      
      状态(最后一步):d[n]
      初始化:dp[1] = 1 ; dp[2] = 1 ;
      边界条件:n<=2;
      状态转移方程:dp[i] = dp[i-1]+dp[i-2]; 	//dp[i]的状态,要么从i-1的台阶跳1级到i	; 要么从i-2级台阶一次跳2级到i
      计算顺序:1-->n 	//计算 dp[i] 需要先计算 dp[i-1] 和 dp[i-2]
    
public int jumpFloor(int n){
	if(n<=2) return n;
	int[] dp = new int[n+1];
	dp[1] = 1;
	dp[2] = 1;
	for(int i=3;i<=n;i++{
		dp[i] = dp[i-1]+dp[i-2];
	}
	return dp[n];
}

4.变态跳台阶

题目描述:一只青蛙可以跳上1级台阶,也可以跳上2级…它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。
在这里插入图片描述

  • 分析

      最后一步:求 dp[n] //跳上n级台阶的方案数
      初始化:dp[1] = 1,dp[2] = 1,...,dp[n] = 1
      状态转移方程:dp[i] = dp[i-1]+dp[i-2]+...+dp[1]	//从所有台阶上都可以调到i级台阶上去
      计算顺序:1-->n
    
  • 代码实现

public int jumpFloorII(int n){
	int[] dp = new int[n+1];
	Arrays.fill(dp,1);	//把dp数组中所有元素初始化为1
	//对于每一级台阶,方案数都是前面所有台阶的方案数的和
	for(int i=1;i<=n;i++){	
		for(int j=1;j<i;j++){
			dp[i] += dp[j];
		}
	}
	return dp[n];
}

2.我的日常练习汇总(DP)

1.蓝桥真题-----路径

蓝桥真题:路径
在这里插入图片描述

import java.util.Arrays;
import java.util.Scanner;
// 1:无需package
// 2: 类名必须Main, 不可修改

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        //在此输入您的代码...
        //最短路径-->dp
        //最小公倍数 = 两数乘积/最大公约数
        System.out.println(check());
        scan.close();
    }

    public static int check(){
      int[] dp = new int[2021+1];
      //结束条件 
      //初始化
      Arrays.fill(dp,Integer.MAX_VALUE);
      dp[1] = 0;
      dp[2] = 2;
      
      for(int i=3;i<=2021;i++){
        for(int x=i-21;x<i;x++){
          if(x<=0) continue;
          dp[i] = Math.min((dp[x] + lcm(i,x,gcb(i,x))) , dp[i]);
        }
      }
      return dp[2021];
    }

    public static int gcb(int a,int b){
      if(b == 0) return a;
      return gcb(b,a%b);
    }
    public static int lcm(int a,int b,int gcb){
      return (a*b)/gcb;
    }
}

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

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

相关文章

ubuntu安装nginx以及开启文件服务器

1. 下载源码 下载页面&#xff1a;https://nginx.org/en/download.html 下载地址&#xff1a;https://nginx.org/download/nginx-1.24.0.tar.gz curl -O https://nginx.org/download/nginx-1.24.0.tar.gz2. 依赖配置 sudo apt install gcc make libpcre3-dev zlib1g-dev ope…

轨迹规划 | 图解最优控制LQR算法(附ROS C++/Python/Matlab仿真)

目录 0 专栏介绍1 最优控制理论2 线性二次型问题3 LQR的价值迭代推导4 基于差速模型的LQR控制5 仿真实现5.1 ROS C实现5.2 Python实现5.3 Matlab实现 0 专栏介绍 &#x1f525;附C/Python/Matlab全套代码&#x1f525;课程设计、毕业设计、创新竞赛必备&#xff01;详细介绍全…

护眼台灯什么品牌好?揭秘护眼台灯十大排名

台灯作为我们日常生活中使用率较高的照明工具&#xff0c;光源的品质也是很重要的&#xff01;如果长时间使用一款质量不好的台灯&#xff0c;可能会影响我们的眼睛健康&#xff0c;特别是孩子的眼睛&#xff0c;还没有发育完全&#xff0c;影响更大。 要知道市面上很多劣质台…

IT廉连看——SpringBoot——SpringBoot快速入门

IT廉连看——SpringBoot——SpringBoot快速入门 1、idea创建工程 &#xff08;1&#xff09;普通Maven工程创建 工程名spring-boot-test 2、添加依赖 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/PO…

理解 Golang 变量在内存分配中的规则

为什么有些变量在堆中分配、有些却在栈中分配&#xff1f; 我们先看来栈和堆的特点&#xff1a; 简单总结就是&#xff1a; 栈&#xff1a;函数局部变量&#xff0c;小数据 堆&#xff1a;大的局部变量&#xff0c;函数内部产生逃逸的变量&#xff0c;动态分配的数据&#x…

人工智能的分类有哪些

人工智能&#xff08;AI&#xff09;可以根据不同的分类标准进行分类。以下是一些常见的分类方法&#xff1a; 1. **按功能分类**&#xff1a; - 弱人工智能&#xff08;Narrow AI&#xff09;&#xff1a;也称为狭义人工智能&#xff0c;指专注于执行特定任务的AI系统&…

【蓝桥杯嵌入式】第十三届省赛(第二场)

目录 0 前言 1 展示 1.1 源码 1.2 演示视频 1.3 题目展示 2 CubeMX配置(第十三届省赛第二场真题) 2.1 设置下载线 2.2 HSE时钟设置 2.3 时钟树配置 2.4 生成代码设置 2.5 USART1 2.5.1 基本配置 2.5.2 NVIC 2.5.3 DMA 2.6 TIM 2.6.1 TIM2 2.6.2 TIM4 2.6.3 …

【Linux】 OpenSSH_9.3p1 升级到 OpenSSH_9.6p1(亲测无问题,建议收藏)

&#x1f468;‍&#x1f393;博主简介 &#x1f3c5;CSDN博客专家   &#x1f3c5;云计算领域优质创作者   &#x1f3c5;华为云开发者社区专家博主   &#x1f3c5;阿里云开发者社区专家博主 &#x1f48a;交流社区&#xff1a;运维交流社区 欢迎大家的加入&#xff01…

品牌门店稽查可调研内容

执行门店稽查的方式主要分为两类&#xff0c;明访和暗访&#xff0c;调研形式的不同&#xff0c;使得调查内容也有所差距&#xff0c;为了保证调研数据的真实性&#xff0c;目前稽查多为暗访&#xff0c;只有在需要对门店导购等的专业素养&#xff0c;或者产品库存盘点时做明访…

JAVA毕业设计134—基于Java+Springboot+Vue的社区医院管理系统(源代码+数据库+万字论文)

毕设所有选题&#xff1a; https://blog.csdn.net/2303_76227485/article/details/131104075 基于JavaSpringbootVue的社区医院管理系统(源代码数据库万字论文)134 一、系统介绍 本项目前后端分离&#xff0c;分为管理员、用户、医生、前台四种角色 1、用户&#xff1a; 注…

有大学老师正用ChatGPT批改论文,让同学也这么做!

4月7日&#xff0c;CNN消息&#xff0c;美国伊萨卡学院-战略传播学教授Diane Gayeski&#xff0c;正在使用ChatGPT批改学生的论文。 当Diane收到学生提交的论文时&#xff0c;会将部分内容输入到ChatGPT&#xff0c;然后让其进行评分并给出详细的修改建议。 Diane也会让班里的…

js控制字数

效果图 js方法 // 控制字数新闻**描述**字数 const delNews () >{let limit 80;if(allObj.newsList && allObj.newsList.length > 0){allObj.newsList.forEach(item>{if(item.contentDescribe.length>80){item.contentDescribeitem.contentDescribe.sub…

mac系统内存(RAM)清理方法,一键式清理工具推荐!

在现代计算机体系结构中&#xff0c;运行内存&#xff08;RAM&#xff09;扮演着关键角色&#xff0c;是保证系统流畅高效运作的核心组件之一。RAM作为一种瞬态存储媒介&#xff0c;专门用来存放当前活跃的程序及其相关的临时数据。不同于硬盘驱动器&#xff08;HDD&#xff09…

外包干了25天,技术倒退明显

先说情况&#xff0c;大专毕业&#xff0c;18年通过校招进入湖南某软件公司&#xff0c;干了接近6年的功能测试&#xff0c;今年年初&#xff0c;感觉自己不能够在这样下去了&#xff0c;长时间呆在一个舒适的环境会让一个人堕落&#xff01; 而我已经在一个企业干了四年的功能…

蓝桥杯练习系统(算法训练)ALGO-957 P0703反置数

资源限制 内存限制&#xff1a;256.0MB C/C时间限制&#xff1a;1.0s Java时间限制&#xff1a;3.0s Python时间限制&#xff1a;5.0s 一个整数的反置数指的是把该整数的每一位数字的顺序颠倒过来所得到的另一个整数。如果一个整数的末尾是以0结尾&#xff0c;那么在它的…

rsync 远程同步----------安全高效的异地备份策略

目录 一、rsync介绍 rsync和cp的区别 rsync和scp的区别 二、rsync同步方式 rsync备份的方式 三、配置rsync源服务器 ①本地复制 ②下行同步 ③上行同步 四、常用Rsync命令 五、配置源的两种表达方法 六、部署rsync下行同步 ①环境准备 ②配置rsync源服务器-------…

瞎写01 CSDN点1个赞[Python][JavaScript]

前言 瞎写系列&#xff0c;记录我那些突如其来的灵感和尝试&#xff0c;整理一些成功或者失败的尝试&#xff0c;虽然还是失败居多一些~&#x1f95d;&#x1f95d; 重要提醒&#xff1a;自动化操作虽然方便&#xff0c;但也有其风险性。本文内容仅作为入门学习之用&#xff0…

使用VPN时,Java程序无法访问远程网络的解决办法

应用场景&#xff1a; 电脑连接VPN之后&#xff0c;Java程序无法连接远程服务&#xff0c;比如第三方接口、远程数据库连接、远程微服务等。我个人遇到的情况有连接海康威视SDK&#xff0c;influxdb以及一些微服务。 解决办法&#xff1a; 启动Java时加入参数&#xff1a;-D…

linux学习:shell脚本

目录 要求 注意 变量 变量的定义和赋值 变量的引用 变量的种类 设置环境变量 特殊符号 引号 竖杠&#xff08;管道&#xff09; 和大于小于号&#xff08;重定向&#xff09; 字符串处理 测试语句 脚本语法 判断 循环 函数 trap 前提 要把 Shell 命令放到一…

《C语言深度解剖》(2):详解C语言分支语句和循环

&#x1f921;博客主页&#xff1a;醉竺 &#x1f970;本文专栏&#xff1a;《C语言深度解剖》 &#x1f63b;欢迎关注&#xff1a;感谢大家的点赞评论关注&#xff0c;祝您学有所成&#xff01; ✨✨&#x1f49c;&#x1f49b;想要学习更多数据结构与算法点击专栏链接查看&am…