当前位置: 首页 > news >正文

企业网站的开发流程上海市建设工程安全生产协会网站

企业网站的开发流程,上海市建设工程安全生产协会网站,郴州网站优化公司,顺企网官网企业名录1.数的划分 题目描述 将整数 nn 分成 kk 份,且每份不能为空,任意两份不能相同(不考虑顺序)。 例如:n7,k3n7,k3,下面三种分法被认为是相同的。 1,1,5;1,5,…

1.数的划分

题目描述

将整数 nn 分成 kk 份,且每份不能为空,任意两份不能相同(不考虑顺序)。

例如:n=7,k=3n=7,k=3,下面三种分法被认为是相同的。

1,1,5;1,5,1;5,1,1;1,1,5;1,5,1;5,1,1;

问有多少种不同的分法。

输入描述

输入一行,22 个整数 n,k (6≤n≤200,2≤k≤6)n,k (6≤n≤200,2≤k≤6)。

输出描述

输出一个整数,即不同的分法。

输入输出样例

示例 1

输入

7 3

输出

4

递归解题思路

看到“整数分拆”问题,直接想到“递归”

递归的核心思想:将大问题分解为小问题,通过解决小问题来构建大问题的解。

递归的终止条件:

  1. nm 为 0,或者 n 小于 m 时,分拆方式数量为 0。

  2. m 为 1 或 n 等于 m 时,分拆方式数量为 1。

递归的分解逻辑:

  1. 不选1的情况:将每个数字减去1,问题转化为 f(n - m, m)

  2. 选1的情况:其中一个数字是1,问题转化为 f(n - 1, m - 1)

最终结果是两种情况的和:f(n - m, m) + f(n - 1, m - 1)

解题步骤模板:

public static int f(int n, int m) {// 边界条件if (n == 0 || m == 0 || n < m) {return 0;}if (m == 1 || n == m) {return 1;}// 递归逻辑else {return f(n - m, m) + f(n - 1, m - 1);}
}

示例代码模板:

import java.util.Scanner;public class Main {// 递归函数,用于计算将整数 n 分成 m 份的方式数public static int f(int n, int m) {// 边界条件:当 n 或 m 为 0,或者 n 小于 m 时,分拆方式数量为 0if (n == 0 || m == 0 || n < m) {return 0;}// 当 m 为 1 或 n 等于 m 时,分拆方式数量为 1if (m == 1 || n == m) {return 1;}// 递归逻辑:// 1. 不选1的情况:将每个数字减去1,问题转化为 f(n - m, m)// 2. 选1的情况:其中一个数字是1,问题转化为 f(n - 1, m - 1)// 总分拆方式数量为两者的和else {return f(n - m, m) + f(n - 1, m - 1);}}// 主函数,程序入口public static void main(String[] args) {// 创建 Scanner 对象,用于读取用户输入Scanner sc = new Scanner(System.in);// 读取用户输入的整数 nint n = sc.nextInt();// 读取用户输入的整数 kint k = sc.nextInt();// 调用递归函数 f(n, k),计算分拆方式数量// 输出结果System.out.println(f(n, k));}
}

思维导图:

训练方法:

  1. 理解递归思想:仔细阅读代码,确保理解递归的终止条件和递归逻辑。

  2. 手算小例子:选择一个小的例子(如 n = 4m = 2),手动计算递归调用的过程,然后用代码验证结果。

  3. 调试和优化:观察递归调用的深度和次数,尝试用记忆化技术优化代码,避免重复计算。

  4. 扩展应用:将代码逻辑应用到其他类似问题,如“将整数分成任意多份”的问题

2.数的计算

题目描述

输入一个自然数 n (n≤1000)n (n≤1000),我们对此自然数按照如下方法进行处理:

  1. 不作任何处理;

  2. 在它的左边加上一个自然数,但该自然数不能超过原数的一半;

  3. 加上数后,继续按此规则进行处理,直到不能再加自然数为止。

问总共可以产生多少个数。

输入描述

输入一个正整数 nn。

输出描述

输出一个整数,表示答案。

输入输出样例

示例 1

输入

6

输出

6

递归解题思路

看到“整数分拆”问题,直接想到“递归”

递归的核心思想:将大问题分解为小问题,通过解决小问题来构建大问题的解。

递归的终止条件:当 n == 1 时,分拆方式数量为 1。

递归的分解逻辑:通过遍历从1到n/2的数i,每次将当前数i分拆,并递归计算i的分拆方式。

解题步骤模板:

public static void f(int n) {// 递归终止条件if (n == 1) {return;}// 遍历 i 从 1 到 n/2,计算分拆方式for (int i = 1; i <= n / 2; i++) {// 每次分拆时,增加结果计数res++;// 递归计算更小的整数 i 的分拆方式f(i);}
}

示例代码模板:

import java.util.Scanner;public class Main {// 全局变量,用于存储最终结果static int res = 1;// 递归函数,用于计算整数 n 的分拆方式数量public static void f(int n) {// 递归终止条件:当 n == 1 时,分拆方式数量为 1if (n == 1) {return;}// 遍历 i 从 1 到 n/2,计算分拆方式for (int i = 1; i <= n / 2; i++) {// 每次分拆时,增加结果计数res++;// 递归计算更小的整数 i 的分拆方式f(i);}}// 主函数,程序入口public static void main(String[] args) {// 创建 Scanner 对象,用于读取用户输入Scanner sc = new Scanner(System.in);// 读取用户输入的整数 nint n = sc.nextInt();// 调用递归函数 f(n),计算分拆方式数量f(n);// 输出最终结果System.out.println(res);}
}

思维导图:

训练方法:

  1. 理解递归思想:仔细阅读代码,确保理解递归的终止条件和递归逻辑。

  2. 手算小例子:选择一个小的例子(如 n = 4),手动计算递归调用的过程,然后用代码验证结果。

  3. 调试和优化:观察递归调用的深度和次数,尝试用记忆化技术优化代码,避免重复计算。

  4. 扩展应用:将代码逻辑应用到其他类似问题,如“将整数分成特定数量的份”或“将整数分成不相等的份”的问题。

 

 自学蓝桥杯笔记,希望我们可以一起学习!

http://www.dtcms.com/a/501866.html

相关文章:

  • 免费网站排名优化wordpress 目录改变
  • php做旅游网站杭州清风室内设计培训学校
  • 冷饮店怎么做网站南阳做网站 汉狮公司
  • 付费网站怎么做海南海口网站开发公司
  • 做网站可以赚多少钱工信和信息化网站备案系统
  • 上海知名的网站建设公司织梦网站下载
  • wordpress网站搬家教程购物商城平台有哪些
  • 有服务器有域名怎么做网站郑州网站优化推广培训
  • 17网站一起做网店白沟做网站设计师的原因
  • 网站设计与管理论文有做材料的网站吗
  • 无锡做智能网站网站建设方案分析
  • 商城网站建设模板下载网站模板打包
  • 网站改进建议新开传奇网站发布站
  • 个人网站注册平台无代码建站软件
  • 沈阳唐朝网站建设怎样开发自己的app
  • 网站服务器基本要素有哪些织梦手机网站模板
  • asp.net不适合做网站叙述网站的建设意义所在
  • 做网站dreamwa东莞如何搭建网站建设
  • 广州 骏域网站建设专家网络规划设计师教程(第2版)pdf
  • 网站建设用什么程序语言wordpress 外贸
  • 做网站用什么技术中文字体怎么设计网站
  • 个人网站开发是学什么语言深圳百度推广开户
  • 网站添加关键字把静态图片做成动态图片的软件
  • 无锡网站优化价格jquery制作简单的网页
  • 交通运输企业标准建设网站东营机关建设网站
  • 杭州网站优化外包管理系统网站开发报价
  • 服务佳的广州网站建设怎么做微信上的网站
  • 咸阳网站建设xymokj建设工程网站新专家入库
  • 大连网站建设在线什么是网站开发技术
  • 提高分辨率网站wordpress网站主机