递归函数设计技巧

如何设计递归函数

要学会如何设计递归函数,首先要识别什么样的问题才适合递归函数求解,那么我们可以通过数学归纳法,分析问题,观察问题是否符合相关性质。

数学归纳法

数学归纳法,是一种基本的数学证明方法,通过对于基础情况的验证,假设某种规律存在,通过层次递推,进而证明该规律的一般性。

基本步骤

  • STEP1: 验证P(1)是正确的。

  • STEP2:: 假设P(K)是正确的,证明P(K + 1)也是正确的。

  • STEP3: 联立STEP1和STEP2,证明P(1)到P(N)是正确的。

证明示例

  • 证明: 1 + 3 + … + ( 2 N − 1 ) = N 2 1 + 3 + … + (2N - 1) = N^2 1+3++(2N1)=N2

    答案:根据数学归纳法的基本步骤:

    ① 验证:P(1) = 1 * 1 = 1;

    ② 假设P(K)成立, 那么P(K + 1) = P(K) + (2(K + 1) - 1) ,展开可以得到, K 2 + 2 K + 1 = ( K + 1 ) 2 K^2 + 2K + 1 = (K + 1)^2 K2+2K+1=(K+1)2
    即: P ( K + 1 ) = ( K + 1 ) 2 P(K + 1) = (K + 1)^2 P(K+1)=(K+1)2

    ③ 联立①和②当K增加到N时,P(N) = N 2 N^2 N2

结构归纳法

在代码设计中,数学归纳法也叫做结构归纳法,可以验证对应代码结构的正确性,使用相关方法验证程序正确性,可以减少程序出问题的概率

递归函数设计的三个步骤

  • 首先:赋予递归函数一个明确的语义信息
  • 其次:实现处于边界条件情况下的代码逻辑
  • 最后:假设递归函数执行结果是正确的,实现本层函数逻辑

递归函数设计示例

  • 递归求阶乘

    int func(int n) {//首先:赋予递归函数明确的语义信息if (n == 1) return 1;//其次:处理边界条件return func(n - 1) * n;//最后:假设函数调用结果正确,实现本层代码逻辑
    }
    

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

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

相关文章

深度解析RocketMq源码-IndexFile

1.绪论 在工作中,我们经常需要根据msgKey查询到某条日志。但是,通过前面对commitLog分析,producer将消息推送到broker过后,其实broker是直接消息到达broker的先后顺序写入到commitLog中的。我们如果想根据msgKey检索一条消息无疑…

Zookeeper:基于Zookeeper的分布式锁

一、Zookeeper分布式锁原理 二、Zookeeper JavaAPI操作 1、Curator介绍 Curator是Apache Zookeeper的Java客户端。常见的Zookeeper Java API: 原生Java API。ZkClient。Curator。 Curator项目目标是简化Zookeeper客户端的使用。Curator最初是Netfix研发的&#xf…

LIMS系统选型时应该避免哪些误区呢

LIMS实验室管理系统在选型、实施及使用过程中,确实存在一些常见的误区。以下是对这些误区的详细解析和归纳: 一、误区 1、只关注功能而忽视用户需求 在LIMS系统的选型过程中,实验室可能过于关注系统的功能和技术特性,而忽视了实…

42.option方法给服务端和客户端配置参数

客户端是Bootstrap.option方法配置参数。 服务端有两个: 1.ServerBootstrap.option方法,给ServerSocketChannel配置参数的。 2.ServerBootstrap.childOption方法,给SocketChannel配置参数的。 package com.xkj.client;import com.xkj.message.*; import com.xkj.protoco…

K近邻回归原理详解及Python代码示例

K近邻回归原理详解 K近邻回归(K-Nearest Neighbors Regression, KNN)是一种基于实例的学习算法,用于解决回归问题。它通过找到输入数据点在特征空间中最相似的K个邻居(即最近的K个数据点),并使用这些邻居的…

C++11的可变参数模板

可变参数模板 什么是可变参数模板的可变参数展开参数包emplace系列函数引例emplace系列函数 什么是可变参数 printf和scanf中就涉及可变参数 这里三个点就代表可变参数,意思就是不管你传多少个参数,都可以接收 printf("%d",x); printf("…

狼牙山短视频:成都柏煜文化传媒有限公司

狼牙山短视频:记录自然与历史的交融 随着短视频的兴起,我们得以在短短几分钟内,跨越千山万水,领略世界各地的风情。成都柏煜文化传媒有限公司 而今天,我想带大家走进一个独特的地方——狼牙山,通过一系列短…

centos挂载新的磁盘

如果是vmware的话,在管理界面,为虚拟机创建一个新的磁盘,然后需要给这个磁盘分区 https://juejin.cn/post/6987200157733371935 1、执行如下命令,查询磁盘分区的UUID。 blkid 磁盘分区 以查询磁盘分区“/dev/vdb1”的UUID为例&am…

Spring Boot中的异常处理策略

Spring Boot中的异常处理策略 大家好,我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!今天我们将探讨在Spring Boot应用程序中如何有效地处理异常,保证系统的…

Transformer教程之Transformer的历史背景

在现代人工智能领域,Transformer模型已经成为一种不可或缺的技术,它在自然语言处理(NLP)和计算机视觉等多个领域取得了巨大的成功。本文将带你回顾Transformer的历史背景,了解它是如何从最初的构想到今天的广泛应用的。…

英国Essay写作攻略怎么才算详细?

写Essay是所有英国留学生都要面对的,很多刚到英国的留学生为了拿到一个完美的成绩单,都会选择找人Essay写作,从而拿到高分。可是你有没有想过,为什么Essay写作能拿高分,而自己写的Essay一直在及格线边上徘徊&#xff0…

Element-UI表单验证 二选一、三选一、多选一验证

Element-UI表单验证二选一验证 在表单提交过程中很多时候要用到几个表单项二选一验证或多选一验证,比如联系方式中的手机号和固定电话只需要填写一项就可通过验证,针对这样情况可以使用Element-UI的自定义验证实现,具体实现方法如下。 HTML…

Web渗透:文件包含漏洞

Ⅱ.远程文件包含 远程文件包含漏洞(Remote File Inclusion, RFI)是一种Web应用程序漏洞,允许攻击者通过URL从远程服务器包含并执行文件;RFI漏洞通常出现在动态包含文件的功能中,且用户输入未经适当验证和过滤。接着我…

520. 检测大写字母 Easy

我们定义,在以下情况时,单词的大写用法是正确的: 全部字母都是大写,比如 "USA" 。 单词中所有字母都不是大写,比如 "leetcode" 。 如果单词不只含有一个字母,只有首字母大写&#xff0…

生产者发送数据,kafka服务器接收数据异常的问题记录

现象: 某个客户要求审计日志用kafka的方式传输给他们,使用了第三方的librdkafka库来开发。 往客户提供的kafka服务器上的一个topic发送数据,这个topic有三个分区,客户反馈接收到的数据和发送端发送的实际数量对不上,他…

代码随想录第五十二天打卡

647. 回文子串 动态规划解决的经典题目&#xff0c;如果没接触过的话&#xff0c;别硬想 直接看题解。 代码随想录 class Solution { public:int countSubstrings(string s) {vector<vector<bool>>dp(s.size(),vector<bool>(s.size(),false));int res0;for …

使用VMware创建Ubuntu 24.04【一】

相关链接下载地址 VMware https://www.vmware.com/content/vmware/vmware-published-sites/cn/products/workstation-pro/workstation-pro-evaluation.html.html.html Ubuntu 24.04 LTS https://cn.ubuntu.com/download/desktop 虚拟机创建 1、打开VNware软件&#xff0c;点…

5.9k!一款清新好用的后台管理系统!【送源码】

今天给大家分享的开源项目是一个优雅清新后台管理系统——Soybean Admin。 简介 官方是这样介绍这个项目的&#xff1a; Soybean Admin 使用的是Vue3作为前端框架&#xff0c;TypeScript作为开发语言&#xff0c;同时还整合了NaiveUI组件库&#xff0c;使得系统具有高可用性和…

Vue 3 的 <script setup> 语法糖中的e

在 Vue 3 的 <script setup> 语法糖中&#xff0c;可以通过直接在模板的事件监听器中访问事件对象&#xff08;通常命名为 e 或 event&#xff09;来传递它到方法。 以下是一个简单的例子&#xff0c;展示了如何在 Vue 3 的 <script setup> 中获取到 mousemove 事…