实验一 分治与递归—整数划分 java实现

简介:

 基本题一:基本递归算法

一、实验目的与要求

1、  熟悉Java语言的集成开发环境;

2、通过本实验加深对递归过程的理解

二、实验内容:

掌握递归算法的概念和基本思想,分析并掌握“整数划分”问题的递归算法。

三、实验题

任意输入一个整数,输出结果能够用递归方法实现整数的划分。

源代码:

四、题目

/*整数划分:

*       -|=1                                     n=1,m=1

*q(n,m) -|=q(n,n)                         n<m

*            -|=1+q(n,n-1)                        n=m

*            -|=q(n,m-1)+q(n-m,m)       n>m>1

*            -

*

*

*其中q(n,m),n表示的是要划分的数,m表示的是划分不大于m

*例如:

*n=6

*5+1;

*4+2,4+1+1,

*3+3,3+2+1,3+1+1+1;

*2+2+2,2+2+1+1,2+1+1+1+1,2+1+1+1+1;

*1+1+1+1+1+1

*

*

*/

 

五、程序代码

importjava.util.*;

import java.io.*;

 

 

public class  SF_ZhenshuHuafen

{

       public static int q(intn,int m){

              if((n<1)||(m<1)) return 0;

              if((n==1)||(m==1))return 1;

              if(n<m)return q(n,n);

              if(n==m)return q(n,m-1)+1;

              return q(n,m-1)+q(n-m,m);

       }

       public static void main(String[] args)

       {

              intn,m,s;

              Scanner read=new Scanner(System.in);

              System.out.println("请输入n");

              n=read.nextInt();

              System.out.println("请输入m");

              m=read.nextInt();

             

              s=q(n,m);

 

 

              System.out.println(s);

       }

}

 

输入:6  3

结果:

 



本文转自 梦朝思夕 51CTO博客,原文链接:http://blog.51cto.com/qiangmzsx/818742

相关文章
|
2月前
|
Java
Java中整数(负数)的二进制表示
Java中整数(负数)的二进制表示
|
2月前
|
监控 数据可视化 Java
Java代码如何轻松实现实验数据监控
Java代码如何轻松实现实验数据监控
25 0
|
3天前
|
Java
java中递归实例
java中递归实例
14 0
|
3天前
|
Java C语言
详解java方法与递归
详解java方法与递归
9 3
|
12天前
|
自然语言处理 Java 编译器
【Java探索之旅】方法重载 递归
【Java探索之旅】方法重载 递归
10 0
|
16天前
|
SQL Java 关系型数据库
java 递归返回树形组织结构(附带树形菜单的搜索)
java 递归返回树形组织结构(附带树形菜单的搜索)
14 0
|
1月前
|
算法 JavaScript Java
Java多线程+分治求和,太牛了
`shigen`,一位擅长Java、Python、Vue和Shell的博主,分享编程知识和成长体验。在一次面试中因对高并发问题准备不足而受挫,随后深入学习,研究了线程池和经典案例——计算1亿数字的和。采用分治策略,`shigen`实现了Java版的归并排序,并对比了Python的简洁实现。通过多线程和分段求和优化,展示了如何高效解决大数求和问题,引入了分治思想的递归任务来进一步提升性能。未来将探讨`forkjoin`框架。关注`shigen`,每天学习新知识!
18 0
Java多线程+分治求和,太牛了
|
1月前
|
存储 Java 关系型数据库
实验设备管理系统【GUI/Swing+MySQL】(Java课设)
实验设备管理系统【GUI/Swing+MySQL】(Java课设)
11 0
|
2月前
|
算法 Java
Java必刷入门递归题×5(内附详细递归解析图)
Java必刷入门递归题×5(内附详细递归解析图)
26 1
|
2月前
|
算法 Java 开发者
Java:求正整数分解为质因数Java
Java:求正整数分解为质因数Java