Activiti——将绘制的流程图存入act数据库并进行流程推进与状态流转

文章目录

  • 前言
  • 流程图入库操作 RepositoryService
    • 项目结构
    • 数据库连接配置文件
    • 入库Java测试代码
    • zip 方式进行流程的批量部署
  • 流程启动 RuntimeService
  • 待处理任务查看 TaskService
  • 流程状态的扭转
  • 查询流程定义信息 RepositoryService
  • 查询正在执行的流程实例 RuntimeService
  • 已部署流程删除
  • 查询流程的历史记录信息 HistoryService

前言

之前的博客中,重点说明了activiti表的创建,以及第一张流程图的绘制。但是绘制的第一张流程图并非存在于对应的数据库中,今天需要做的就是将绘制的流程图,使用activiti的代码自动的填充进对应的数据表中。然后做一个简单的状态流转。

流程图入库操作 RepositoryService

项目结构

依旧是基于之前的项目依赖与结构。
在这里插入图片描述

数据库连接配置文件

其中数据库的连接配置文件activiti.cfg.xml,配置内容如下所示:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:tx="http://www.springframework.org/schema/tx"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
	http://www.springframework.org/schema/beans/spring-beans.xsd
	http://www.springframework.org/schema/contex
	http://www.springframework.org/schema/context/spring-context.xsd
	http://www.springframework.org/schema/tx
	http://www.springframework.org/schema/tx/spring-tx.xsd">

    <bean id="processEngineConfiguration" class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration">
        <property name="jdbcDriver" value="com.mysql.cj.jdbc.Driver"/>
        <property name="jdbcUrl" value="jdbc:mysql://xxxx:3306/activiti_02?useSSL=false&amp;useUnicode=true&amp;characterEncoding=utf-8&amp;serverTimezone=GMT%2B8&amp;nullCatalogMeansCurrent=true"/>
        <property name="jdbcUsername" value="root"/>
        <property name="jdbcPassword" value="root"/>
        <property name="databaseSchemaUpdate" value="true"/>
    </bean>

   <!-- <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver" />
        <property name="url" value="jdbc:mysql://xxxx:3306/activiti?useSSL=false&amp;useUnicode=true&amp;characterEncoding=utf-8&amp;serverTimezone=GMT%2B8" />
        <property name="username" value="root" />
        <property name="password" value="root" />
        <property name="maxActive" value="3" />
        <property name="maxIdle" value="1" />
    </bean>

    <bean id="processEngineConfiguration" class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration">
        <property name="dataSource" ref="dataSource" />
        <property name="databaseSchemaUpdate" value="true"/>
    </bean>-->

</beans>

配置文件中的一些注意事项在前面的博客中做了一些说明,此处不进行额外的讲解,有问题的参考之前的博客内容。

入库Java测试代码

编写一个测试类,其中的入库逻辑如下所示:

// 单个任务的部署
@Test
public void addTable(){
    ProcessEngine defaultProcessEngine = ProcessEngines.getDefaultProcessEngine();
    RepositoryService repositoryService = defaultProcessEngine.getRepositoryService();
    Deployment demo1 = repositoryService.createDeployment()
            .addClasspathResource("bpmn/demo01.bpmn") // 添加流程图
            .addClasspathResource("bpmn/demo01.png") // 对应的流程图片 支持 png|jpg|gif|svg
            .name("第一个流程测试用例")
            .deploy();
    System.out.println("流程部署id===》"+demo1.getId());
    System.out.println("流程部署name===》"+demo1.getName());
}

虽然都是使用addClasspathResource关联xml与png 图片,但是其中的底层原理则是根据文件后缀,自动去判断识别存入对应的数据表字段中。

查看控制台输出日志与数据库,可以发现能够将对应的流程图xml与流程图进行入库处理。

在这里插入图片描述
查看数据库是否存在对应的数据信息。

select * from ACT_RE_DEPLOYMENT;
select * from ACT_RE_PROCDEF;

在这里插入图片描述
在这里插入图片描述
上传后的文件内容存储表,可以通过查找act_ge_bytearray看见。
在这里插入图片描述
【注意点】

除了流程图的最初部署,会将流程图存入act_ge_bytearray表之外。
在流程审批的各个节点中,都能将对应的文件进行存储,方便后续进行文件的回显。

zip 方式进行流程的批量部署

将对应的 流程图 png 与 xml 汇总打包成一个zip文件,此时则需要注意 两个文件除了后缀不同之外,一定要保证前面的文件名称一致。
在这里插入图片描述
编写代码逻辑,将zip创建数据流,并使用activiti的DeploymentaddZipInputStream,将zip数据流解析并存入数据表中。

/**
 * zip 包方式批量上传流程图与流程xml文件
 */
@Test
public void zipInsertTable(){
    // 获取zip文件流
    InputStream inputStream = this.getClass()
            .getClassLoader()
            .getResourceAsStream("bpmn/activitis.zip");
    ZipInputStream zipInputStream = new ZipInputStream(inputStream);

    ProcessEngine defaultProcessEngine = ProcessEngines.getDefaultProcessEngine();
    RepositoryService repositoryService = defaultProcessEngine.getRepositoryService();

    Deployment deploy = repositoryService.createDeployment()
            .addZipInputStream(zipInputStream)
            .deploy();

    System.out.println("流程部署id===》"+deploy.getId());
    System.out.println("流程部署name===》"+deploy.getName());
}

代码执行后,观察控制台打印日志信息与数据表的查询。
在这里插入图片描述

select * from ACT_RE_PROCDEF;

在这里插入图片描述
流程的部署操作,是将文件 xml 、png 解析并存入到activiti对应的数据表的字段中。上述两种方式,分别就单一与批量进行了验证,通过查看执行的日志信息,可以发现其中受影响的表有以下几种:

  • act_re_deployment 流程定义部署表 。每执行一次部署,则会增加一条记录;若文件相同,则version字段递增。
  • act_re_procdef 流程定义表。部署每个新的流程定义都会在该表中新增记录。
  • act_ge_bytearray 流程资源表。 主要记录对应文件的 bytearray 信息,数据字段类型为 blob。

流程启动 RuntimeService

当对应的流程图的结构信息已经进行了入库操作,此时就可以编写代码进行流程的启动测试了。
在这里插入图片描述

启动流程的逻辑如下所示:

/**
 * 流程启动  初次启动
 * 注意: 每次执行一次  就是以当前的流程图模板  创建了一个新的 activiti 的对象
 */
@Test
public void startFlow(){
    ProcessEngine defaultProcessEngine = ProcessEngines.getDefaultProcessEngine();
    RuntimeService runtimeService = defaultProcessEngine.getRuntimeService();
    // 注意此处的 key  就是流程图的 id 
    ProcessInstance demo01 = runtimeService.startProcessInstanceByKey("demo01");
    System.out.println("流程定义 id===》"+demo01.getProcessDefinitionId());
    System.out.println("流程实例 id===》"+demo01.getId());
    System.out.println("当前活动 id===》"+demo01.getActivityId());
}

代码执行后查看控制台的相关日志输出。
在这里插入图片描述
【注意点】startProcessInstanceByKey("demo01") 指定的 key 必须与 流程图中的 id 一致
在这里插入图片描述
如果不一致,则会出现org.activiti.engine.ActivitiObjectNotFoundException: no processes deployed with key 'demoxxxx'的报错问题!!

【注意点】每次执行创建流程的代码,都会以工作流流程图作为模板,构建一个新的实例
在这里插入图片描述
在文件部署并填充至activiti数据表中后,执行上述的代码,则会根据已部署好的信息,构建一个新的流程实例。通过执行后的控制台日志,可以发现受影响的表有以下:

  • act_hi_actinst 流程实例执行历史
  • act_hi_identitylink 流程的参与用户历史信息
  • act_hi_procinst 流程实例历史信息
  • act_hi_taskinst 流程任务历史信息
  • act_ru_execution 流程执行信息
  • act_ru_identitylink 流程的参与用户信息
  • act_ru_task 任务信息

待处理任务查看 TaskService

流程启动,在有些项目中的首页,需要展示当前登录者的待处理任务列表信息。

进行了启动工作流操作,此时的工作流中的节点流转,如下:
在这里插入图片描述

此时可以通过TaskService查看,下面是一个简单的例子。

/**
 * 查询当前个人待执行的任务
 */
@Test
public void viewReDoTask(){
    // 工作流从启动开始  就会流转至 第一个 UserTask 节点,
    // 此时可以通过配置的 Assignee 查询指定的人的  一些待处理 任务信息
    String assignee = "worker";
    // 数据库连接配置操作
    ProcessEngine defaultProcessEngine = ProcessEngines.getDefaultProcessEngine();
    // 根据对应的流程 查询当前指定人的待处理任务信息
    TaskService taskService = defaultProcessEngine.getTaskService();
    List<Task> list = taskService.createTaskQuery()
            .processDefinitionKey("demo01") // 指定哪个流程图模板
            .taskAssignee(assignee) // 指定是谁负责待处理的任务
            .list();
    if(!CollectionUtil.isEmpty(list)){
        list.forEach(x->{
            System.out.println("流程实例 id "+x.getProcessInstanceId());
            System.out.println("任务 id "+x.getId());
            System.out.println("任务负责人 "+x.getAssignee());
            System.out.println("任务名称"+x.getName());
            System.out.println("===========================================");
        });
    }
}

测试代码运行后,在控制台中可以看到以下的信息。
在这里插入图片描述

这里有两个流程实例,是因为为了验证启动流程是否同实例对象,执行了两次开启流程的代码逻辑。

流程状态的扭转

work节点中,上面进行了待处理任务的查看操作,如果用户进行了处理,需要将状态进行向下扭转,如何扭转任务的节点,接下来看下面的代码逻辑。

/**
 * 工作流的节点与状态的扭转
 */
@Test
public void doTask(){
    // 获取数据库的连接信息
    ProcessEngine defaultProcessEngine = ProcessEngines.getDefaultProcessEngine();
    TaskService taskService = defaultProcessEngine.getTaskService();
    
    // 完成当前节点的任务  并向下推进
    String taskId = "7505";
    taskService.complete(taskId);
}

在这里插入图片描述

当任务进行推进操作后,再执行查询当前登录人员需要待处理的任务节点,那么任务id为 7505的相关任务不能查询到。查询一下。
在这里插入图片描述

任务编号为7505的已经成功推进!

查询流程定义信息 RepositoryService

再上面的startFlow()执行后,就会依据对应的工作流模板,创建一个工作流流程实例。查看指定的流程模板下已创建的相关流程实例信息,可以使用下面的代码逻辑实现。

/**
 * 查询流程定义 的一些内容
 */
@Test
public void queryProcessDefinition(){
    // 获取数据库的连接信息
    ProcessEngine defaultProcessEngine = ProcessEngines.getDefaultProcessEngine();

    RepositoryService repositoryService = defaultProcessEngine.getRepositoryService();
    ProcessDefinitionQuery processDefinitionQuery = repositoryService.createProcessDefinitionQuery();

    // 指定需要查询哪个流程模板信息
    String flowId = "demo01";
    List<ProcessDefinition> list = processDefinitionQuery
            .processDefinitionKey(flowId) // 指定是哪个流程模板
            .orderByProcessDefinitionVersion() // 排序字段
            .desc()
            .list();
    if(!CollectionUtil.isEmpty(list)){
        list.forEach(process->{
            System.out.println("流程定义 id "+process.getId());
            System.out.println("流程定义 name "+process.getName());
            System.out.println("流程定义 key "+process.getKey());
            System.out.println("流程定义 version "+process.getVersion());
            System.out.println("流程部署 id "+process.getDeploymentId());
            System.out.println("=============================");
        });
    }
}

查看控制台执行后的日志信息,如下所示:
在这里插入图片描述

查询正在执行的流程实例 RuntimeService

如果需要查询当前指定的流程模板,存在哪些流程实例处于流程中的状态,以及对应的流程实例的信息,以达到随时跟踪任务的执行情况。

可以使用如下方式进行查看:

/**
 * 查询指定工作流模板中,哪些实例正在执行流程中
 */
@Test
public void queryDoProcessInstance(){
    // 指定工作流流程模板id
    String flowId= "demo01";
    // 获取数据库的连接信息
    ProcessEngine defaultProcessEngine = ProcessEngines.getDefaultProcessEngine();

    RuntimeService runtimeService = defaultProcessEngine.getRuntimeService();
    List<ProcessInstance> list = runtimeService.createProcessInstanceQuery()
            .processDefinitionKey(flowId)
            .list();
    if(!CollectionUtil.isEmpty(list)){
        list.forEach(processInstance->{
            System.out.println("流程实例 id "+processInstance.getProcessInstanceId());
            System.out.println("所属流程定义 id "+processInstance.getProcessDefinitionId());
            System.out.println("是否执行完成 "+processInstance.isEnded());
            System.out.println("是否暂停 "+processInstance.isSuspended());
            System.out.println("当前活动标识 "+processInstance.getActivityId());
            System.out.println("业务关键字 "+processInstance.getBusinessKey());
            System.out.println("=============================");
        });
    }
}

在这里插入图片描述

已部署流程删除

有些已经部署后的流程,需要进行删除操作,则可以使用下列的逻辑实现。

这里说的已部署,是指已经执行了addTable()做了流程文件的上传操作。

/**
 * 删除 已部署 的流程实例。
 * 注意:如果当前流程实例并未执行完成,进行删除时会出现报错。
 */
@Test
public void deleteDeployment(){
    // 流程部署id
    String deployMentId = "5001";
    // 获取数据库的连接信息
    ProcessEngine defaultProcessEngine = ProcessEngines.getDefaultProcessEngine();
    RepositoryService repositoryService = defaultProcessEngine.getRepositoryService();
    // 当该已部署的流程,存在流程中的实例时,执行当前流程会报错!
    repositoryService.deleteDeployment(deployMentId);
    // 如果需要进行强制删除  则可以采取下列的方式进行
    //repositoryService.deleteDeployment(deployMentId,true);
}

如果当前已部署的流程存在流程中的实例时,执行删除操作会出现下面的报错信息。
在这里插入图片描述

查询流程的历史记录信息 HistoryService

在一般的审批详情列表中,通常需要展示一些已审批处理节点的记录信息,此时则可以使用 HistoryService 查询指定流程实例下的各个已处理的审批节点数据记录。

当然了,测试操作需要指定指定工作流模板的流程id,先查询可以测试的流程编号。

/**
 * 查询指定工作流模板中,哪些实例正在执行流程中
 */
@Test
public void queryDoProcessInstance(){
    // 指定工作流流程模板id
    String flowId= "demo01";
    // 获取数据库的连接信息
    ProcessEngine defaultProcessEngine = ProcessEngines.getDefaultProcessEngine();

    RuntimeService runtimeService = defaultProcessEngine.getRuntimeService();
    List<ProcessInstance> list = runtimeService.createProcessInstanceQuery()
            .processDefinitionKey(flowId)
            .list();
    if(!CollectionUtil.isEmpty(list)){
        list.forEach(processInstance->{
            System.out.println("流程实例 id "+processInstance.getProcessInstanceId());
            System.out.println("所属流程定义 id "+processInstance.getProcessDefinitionId());
            System.out.println("是否执行完成 "+processInstance.isEnded());
            System.out.println("是否暂停 "+processInstance.isSuspended());
            System.out.println("当前活动标识 "+processInstance.getActivityId());
            System.out.println("业务关键字 "+processInstance.getBusinessKey());
            System.out.println("=============================");
        });
    }
}

在这里插入图片描述
使用对应的流程实例id,这里使用10001

使用下列代码进行历史数据的检索:

/**
 * 查询 历史信息
 */
@Test
public void queryHistoryInfo(){
    String processInstanceId = "10001";
    ProcessEngine defaultProcessEngine = ProcessEngines.getDefaultProcessEngine();
    HistoryService historyService = defaultProcessEngine.getHistoryService();
    HistoricActivityInstanceQuery historicActivityInstanceQuery = historyService.createHistoricActivityInstanceQuery();
    historicActivityInstanceQuery.processInstanceId(processInstanceId);// 流程实例id
    historicActivityInstanceQuery.orderByHistoricActivityInstanceStartTime().asc();
    List<HistoricActivityInstance> list = historicActivityInstanceQuery.list();
    if(!CollectionUtil.isEmpty(list)){
        list.forEach(hi->{
            System.out.println(hi.getActivityId());
            System.out.println(hi.getActivityName());
            System.out.println(hi.getProcessDefinitionId());
            System.out.println(hi.getProcessInstanceId());
            System.out.println("=============================");
        });
    }
}

执行成功后在控制台的日志中可以看到下列信息:
在这里插入图片描述

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

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

相关文章

Autosar AP的基本构成

1. 引言 Autosar AP的体系结构是怎样的呢&#xff1f;从整体的宏观的方向上划分&#xff0c;分为 1&#xff09;应用层&#xff0c;其中放置各种应用组件SWCs。2&#xff09;运行时基本功能软件族群&#xff0c;提供基本AutoSar基本软件中间件&#xff0c;比如经典的通信服务…

玩转nginx的配置文件3

1. limit_req_zone配置限流 limit_req_zone $binary_remote_addr zonemylimit:10m rate10r/s;upstream myweb {server 10.0.105.196:80 weight1 max_fails1 fail_timeout1;}server {listen 80;server_name localhost;location /login {limit_req zonemylimit;proxy_pass http:…

嵌入式UBoot如何跳转Kernel—uboot与linux交界分析

不知道你是否有这种感觉,就是学习了Uboot,学习了kernel,学习了安卓。但是有时候总感觉是各自孤立的,将三者连续不起来? • 不知道你是否在做启动方案的时候,在宏观上知道了整个启动链路流程,但是却在汪洋的代码中迷了路? 那么这篇文章必定对你有点用处。 如果没有,那请…

恭喜!喜提美国匹兹堡大学儿童医院访问学者邀请函

➡️【院校简介】 匹兹堡UPMC儿童医院该院是匹兹堡大学医学中心的一部分&#xff0c;也是大匹兹堡唯一一家专门护理26岁以下婴儿&#xff0c;儿童&#xff0c;青少年和年轻人的医院。该医院隶属于匹兹堡大学医学院&#xff0c;设有一个获得州级认证的一级儿科创伤中心&#xf…

Linux的自动化脚本:使用crul命令的从某个网站获取数据(从url获取数据),并将其写入一个文件中

目录 一、要求 二、思路 三、shell脚本实现演练 &#xff08;一&#xff09;脚本实现 &#xff08;二&#xff09;脚本代码说明 &#xff08;三&#xff09;脚本执行 &#xff08;四&#xff09;数据内容 一、要求 Linux的一个进程需要获取一个网站上的最新数据&#xf…

JavaScript:将input标签中的内容打印到控制台

使用浏览器进行开发时&#xff0c;按F12可以查看网页信息。 目标&#xff1a;实现将input标签中的内容&#xff0c;打印到控制台&#xff08;console&#xff09; HTML页面的关键代码实现&#xff1a; 登录功能&#xff1a; HTML代码&#xff1a; <div class"form-…

FastAPI从入门到实战(16)——请求参数汇总

FastAPI有各种各样的参数,包括: url参数(定义在url中的参数)param参数(使用url后面?xxxx)定义的参数body参数(在请求主体中携带的json参数)form参数(在请求主体中携带的web表单参数)cookie参数(在请求的cookie中携带的参数)file参数(客户端上传的文件) 1. url参数 from fas…

【A-034】基于SSH的电影订票系统(含论文)

【A-034】基于SSH的电影订票系统&#xff08;含论文&#xff09; 开发环境&#xff1a; Jdk7(8)Tomcat7(8)MySQLIntelliJ IDEA(Eclipse) 数据库&#xff1a; MySQL 技术&#xff1a; SpringStruts2HiberanteJSPJquery 适用于&#xff1a; 课程设计&#xff0c;毕业设计&…

户外指南——时代产物

分类 一级分类&#xff1a; 衣&#xff1a;除了上述提到的&#xff0c;还包括衣物的材质、款式多样性、与身份地位的关联等。 食&#xff1a;还包括饮食的文化内涵、地域特色、对特殊饮食需求的满足等。 住&#xff1a;还包括居住空间的合理布局、智能家居的应用、与自然环境…

mysql的约束和表关系

根据查询的结果&#xff0c;复制出一个新表 create table newTable AS select * from oldTable; create table newPeople AS select * from day2_test.people; 约束 引入&#xff1a;如果某一列如id列&#xff0c;有重复的数据&#xff0c;无法准确定位&#xff0c;有的列有空…

安装VCenter 7 对硬件资源的需求

安装VMware vCenter Server 7.x 对硬件资源的需求主要包括以下方面&#xff1a; 服务器硬件&#xff1a; 处理器&#xff1a;64位 x86架构&#xff0c;推荐采用多核CPU以支持高并发管理和运行多个虚拟机。具体数量取决于vCenter Server将管理的虚拟机规模及复杂度。内存&#x…

vue系统指令二

vue系统指令二 v-model:双向数据绑定 重点&#xff1a;双向数据绑定&#xff0c;只能用于表单元素&#xff0c;或者用于自定义组件。 之前的文章里&#xff0c;我们通过v-bind&#xff0c;给<input>标签绑定了data对象里的name属性。当data里的name的值发生改变时&#…

未来五十年,智能科技将如何改变传统行业格局?

未来五十年内&#xff0c;随着人工智能&#xff08;AI&#xff09;和智能科技的不断发展&#xff0c;许多行业将面临被取代的风险。虽然这种趋势可能会带来一些担忧&#xff0c;但也将为人类社会带来巨大的变革。下面将详细探讨哪些行业可能会在未来被智能科技所取代。 ▶ 制造…

攻防世界fileclude题解

攻防世界fileclude题解 ​​ 题目要求file1和file2参数不能为空 且file2这个文件内容值为hello ctf&#xff0c;用php://input 然后POST体内输入hello ctf即可满足这个if条件 满足这个条件后就会包含file1变量所指定的那个文件。用php伪协议来跨目录包含一下flag.php文件就可以…

群组分析方法

目录 1.什么是群组分析方法 2.基本原理 3.群组分析方法分类 3.1.层次方法 3.2.划分方法 3.3.密度基方法 ​​​​​​​3.4.模型基方法 4.群组评估 5.应用步骤 1.什么是群组分析方法 群组分析&#xff08;Cluster Analysis&#xff09;是数据分析中的一种重要方法&…

【第3节】“茴香豆“:搭建你的 RAG 智能助理

目录 1 基础知识1.1.RAG技术的概述1.2 RAG的基本结构有哪些呢&#xff1f;1.3 RAG 工作原理&#xff1a;1.4 向量数据库(Vector-DB )&#xff1a;1.5 RAG常见优化方法1.6RAG技术vs微调技术 2、茴香豆介绍2.1应用场景2.2 场景难点2.3 茴香豆的构建&#xff1a; 3 论文快读4 实践…

Swift - Playground

文章目录 Swift - Playground1. 新建Playground2. View3. 图片4. ViewController5. Playground - 多Page6. 注释6.1 Playground的注释支持markup语法&#xff08;与markdown相似&#xff09;6.1.1 语法 Swift - Playground Playground可以快速预览代码效果&#xff0c;是学习语…

SpringCloud系列(15)--Eureka自我保护

前言&#xff1a;在上一章节中我们说明了一些关于Eureka的服务发现功能&#xff0c;也用这个功能进行接口的实现&#xff0c;在本章节则介绍一些关于Eureka的自我保护 1、Eureka保护模式概述 保护模式主要用于一组客户端和Eureka Server之间存在网络分区场景下的保护。默认情况…

chrome插件 脚本 使用和推荐

chrome插件使用 在极简插件中可以进行下载并进行安装, 内部有安装教程在极简插件中搜索"油猴",下载一个油猴插件,并安装,可以用于下载很多的用户脚本用户脚本下载地址Greasy Fork,里面有很多实用的用户脚本供下载,并在油猴中进行管理 推荐的插件 Tampermonkey 篡改…

动态规划---斐波那契数列模型

目录 一、斐波那契数列的基本概念 二、动态规划在斐波那契数列中的应用与优势 三、实际案例&#xff1a;使用动态规划解决斐波那契数列问题 四、动态规划问题的做题步骤 五、例题 1、第N个泰波那契数---点击跳转题目 2、三步问题----点击跳转题目 3、最小花费爬楼梯---…
最新文章