课后作业一:计算组合数

程序设计思想:

从键盘获取组合数,判断是否构成组合数。分别用三种方法计算组合数输出。

程序流程图:

import java.util.Scanner;

public class Test1 {
public static void main(String[] args){
System.out.print("请输入数:");
Scanner sc = new Scanner(System.in);
//从键盘获取组合数
   int n = sc.nextInt();
   System.out.print("请输入组合个数:");
   int k = sc.nextInt();
//判断格式 正确计算组合数
   if(n < k){
System.out.print("输入错误!");
   }
  else{
  System.out.println("组合数计算:" + zhuhe(n, k));
   System.out.println("杨辉三角计算:" + ditui(n, k));
   System.out.println("组合数递推计算:" + digui(n, k));
  }
}
//递归递推计算
public static long digui(int n, int k){
return ditui(n, k);
}
//杨辉三角递推计算
public static long ditui(int n, int k){
long m1, m2, sum;
   m1 = calculateN(n - 1) / (calculateN(k - 1) * calculateN((n - 1) - (k - 1)));
   m2 = calculateN(n - 1) / (calculateN(k) * calculateN((n - 1) - k));
  sum = m1 + m2;
return sum;
} 
//公式计算
public static long zhuhe(int n,int k){
return calculateN(n) / (calculateN(k) * calculateN(n - k));
  }   
//递归计算阶乘
public static long calculateN(int n){
   if(n==1 || n==0){
     return 1;
    }
    return n * calculateN(n - 1);
  }
}

课后作业二:汉诺塔问题

程序设计思想:

把N个盘子从A座移到C座,但每次只能允许移动一个盘子,并且在移动过程中,3个座上的盘子始终保持大盘在下,小盘在上。在移动过程中可以利用B座。

程序流程图:

import java.util.Scanner;

public class Test2{
public static void main(String[] args){
int n;
    System.out.print("输入盘子层数:");
    Scanner sc = new Scanner(System.in);
//从键盘获取盘子数
    n = sc.nextInt();
//递归调用
    hannuo(n, 'A', 'B', 'C');
  }
  public static void hannuo(int n, char a, char b, char c){
//n=1时,将A上的盘子直接移动到C上
if(n == 1){
move(a, c, 1);
   }
   /*
1,将A上n-1个盘子移动到B上(此步骤的解决办法与移动n阶盘子的方法完全一样只是问题的规模减小1阶)
2,将A上的一个盘子移动到C
3,将B上的n-1个盘子移动到C上。 */
   else{
hannuo(n - 1, a, c, b);
   move(a, c, n);
   hannuo(n - 1, b, a, c);
}
  }
//输出操作步骤
  public static void move(char x, char y, int n){
System.out.println(x + "的第个" + n + "盘子移动到" + y);
  }
}

课后作业三:回文字符串

程序设计思想:

从键盘获取字符串,定义数组。数组元素依次获取字符。通过递归方法比较数组元素,判断是否是回文字符串。

程序流程图:

import java.io.*;

public class Test3{
public static void main(String[] args) throws IOException{
String str;
     int i = 0;
    System.out.print("输入字符串:");
//从键盘获取字符串
    BufferedReader buf = new BufferedReader(new InputStreamReader(System.in));
    str = buf.readLine();
//定义数组 数组元素依次获取字符
    char [] ch = str.toCharArray();
//判断是否是回文字符串
    if(huiwen(ch,i) == 1)
     System.out.println("是回文字符串");
    else
     System.out.println("不是回文字符串");
  }
//递归判断回文
  public static int huiwen(char [] ch,int i){
if(i == ch.length / 2 )
     return 1;
     if(ch[i] != ch[ch.length - i - 1])
     return 0;
     huiwen(ch,i + 1);
     return 1;
  }
}

java课后实验性问题2的更多相关文章

  1. java课后实验性问题5

    课后作业一:字符串加密 程序设计思想: 从键盘获取字符串,将字符串转为字符数组,将每个元素加事前协定的“key”,再转为字符串输出. 程序流程图: 源代码: import java.util.Scan ...

  2. java课后实验性问题4

    课后作业一: 使用类的静态字段和构造函数,我们可以跟踪某个类所创建对象的个数.请写一个类,在任何时候都可以向它查询“你已经创建了多少个对象? 设计思路:定义类的构造函数时使静态变量i进行i++,即每构 ...

  3. java课后实验性问题7

    1.异常处理 import javax.swing.*; class AboutException { public static void main(String[] a) { int i = 1, ...

  4. java课后实验性问题6

    1.继承条件下的构造方法调用. class Grandparent { public Grandparent(){ System.out.println("GrandParent Creat ...

  5. java课后实验性问题3

    一 .生成随机数 import java.util.*; public class Test1 { public static void main(String[] args) { //建立一个生产随 ...

  6. java课后实验性问题1

    一.一个java类文件中只能有一个公有类吗? 测试代码 public class Test{ public static void main(String[] args){ } public clas ...

  7. JAVA 数组作业——动手动脑以及课后实验性问题

    JAVA课后作业——动手动脑 一:阅读并运行示例PassArray.java,观察并分析程序输出的结果,小结,然后与下页幻灯片所讲的内容进行对照. 1.源代码 // PassArray.java // ...

  8. JAVA语法基础作业——动手动脑以及课后实验性问题 (八)

    一.动手动脑 运行AboutException.java示例,了解Java中实现异常处理的基础知识. 1)源代码 import javax.swing.*; class AboutException ...

  9. JAVA 多态和异常处理作业——动手动脑以及课后实验性问题

    1.  阅读以下代码(CatchWho.java),写出程序运行结果: 1)  源代码 public class CatchWho { public static void main(String[] ...

随机推荐

  1. 让一个父级div根据子级div高度而自适应高度

    需求是点击上传的时候进行子级div高度不定,相对来说父级div高度也不能固定,把元素都设置成普通标准流,然后样式可以使用margin内边距或者padding外边距来进行调节 放上代码供参考: .opu ...

  2. FlowPortal BPM 验证组的使用方法

    1.在表单上指定验证组 2.在流程上指定验证组 3.启用多个验证组 流程审批线上设置验证组时可以设置多个验证组,多个验证组之间以分号分割,如:AAA;BBB.

  3. stm32 ADC模数转换 ADC多通道 ADC DMA

    通过调节电位器,改变AD转换值和电压值 STM32F1 ADC 配置步骤 1.使能GPIO时钟和ADC时钟 2.配置引脚模式为模拟输入 3.配置ADC的分频因子 4.初始化ADC参数,ADC_Init ...

  4. umi model 注册

    model 分两类,一是全局 model,二是页面 model.全局 model 存于 /src/models/ 目录,所有页面都可引用:页面 model 不能被其他页面所引用. 规则如下: src/ ...

  5. js 执行完setTimeout再接着执行函数

    var counter = 0; function increase(){ var d = jQuery.Deferred(); var doIncrease = function() { if(co ...

  6. pandas行转列、列转行、以及一行生成多行

    楔子 笔者曾经碰到过两种格式的数据,当时确实把我难住了,最后虽然解决了,但是方法不够优雅,而且效率也不高,如果想高效率,那么就必须使用pandas提供的方法.而pandas作为很强的一个库,一定可以优 ...

  7. linux 基础9-账号与身份管理

    1. linux的账号与群组 1.1 账户名称:/etc/passwd: head -n 5 /etc/password #取前5行 账号名称,对应UID 密码,早期是在这里,后来转到了/etc/sh ...

  8. 数据库连接池,DBUtil的模板,dbcp,c3p0

    数据库连接池,DBUtil的模板,Druid使用(重点) 一.DBUtil模板 public class DBUtilTest { public static Connection connectio ...

  9. JavaScript基础习题

    1.实现输入框的双向绑定 解析:所谓双向绑定,即view->model, model->view,可以考虑对象劫持,监听对象属性的变化 <input type="input ...

  10. windows下mysql5.6.x的日志正确配置方法(my.ini) (网上的都是5.6之前的版本)

    https://blog.csdn.net/databatman/article/details/49951853 感谢楼主,找了好久,试了一下楼主的,果然是对的,网上的日志配置都是5.6之前的版本: ...