java课后实验性问题2
课后作业一:计算组合数
程序设计思想:
从键盘获取组合数,判断是否构成组合数。分别用三种方法计算组合数输出。
程序流程图:

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的更多相关文章
- java课后实验性问题5
课后作业一:字符串加密 程序设计思想: 从键盘获取字符串,将字符串转为字符数组,将每个元素加事前协定的“key”,再转为字符串输出. 程序流程图: 源代码: import java.util.Scan ...
- java课后实验性问题4
课后作业一: 使用类的静态字段和构造函数,我们可以跟踪某个类所创建对象的个数.请写一个类,在任何时候都可以向它查询“你已经创建了多少个对象? 设计思路:定义类的构造函数时使静态变量i进行i++,即每构 ...
- java课后实验性问题7
1.异常处理 import javax.swing.*; class AboutException { public static void main(String[] a) { int i = 1, ...
- java课后实验性问题6
1.继承条件下的构造方法调用. class Grandparent { public Grandparent(){ System.out.println("GrandParent Creat ...
- java课后实验性问题3
一 .生成随机数 import java.util.*; public class Test1 { public static void main(String[] args) { //建立一个生产随 ...
- java课后实验性问题1
一.一个java类文件中只能有一个公有类吗? 测试代码 public class Test{ public static void main(String[] args){ } public clas ...
- JAVA 数组作业——动手动脑以及课后实验性问题
JAVA课后作业——动手动脑 一:阅读并运行示例PassArray.java,观察并分析程序输出的结果,小结,然后与下页幻灯片所讲的内容进行对照. 1.源代码 // PassArray.java // ...
- JAVA语法基础作业——动手动脑以及课后实验性问题 (八)
一.动手动脑 运行AboutException.java示例,了解Java中实现异常处理的基础知识. 1)源代码 import javax.swing.*; class AboutException ...
- JAVA 多态和异常处理作业——动手动脑以及课后实验性问题
1. 阅读以下代码(CatchWho.java),写出程序运行结果: 1) 源代码 public class CatchWho { public static void main(String[] ...
随机推荐
- ajax简单页面
简单的注册页面运用ajax 主页面 <head><meta http-equiv="Content-Type" content="text/html; ...
- Marketing Cloud的contact merge机制
Marketing Cloud的contact支持多种多样的数据源,如下图所示: SAP Hybris Commerce SAP ERP SAP Cloud for Customer SAP Gigy ...
- gitlab安装教程 正在修炼的西瓜君
查看内存配置 我们先不急着来安装gitlab,先来看一下自己电脑的内存情况,我把这一步提到最前面,是因为这是我安装过程中遇到的最大的坑. 下面是gitlab的cpu和内存需求(https://do ...
- Thymeleaf整合到Spring Security,标签sec不起作用
将 pom 文件中的 thymeleaf-extras-springsecurity4 依赖改成 thymeleaf-extras-springsecurity5 <dependency> ...
- c多线程不加锁demo
// // Created by gxf on 2019/12/13. // #include <stdio.h> #include <stdlib.h> #include & ...
- Excel 教程一
俗话说,工欲善其事,必先利其器,那么我们今天就先来看一下这个excel软件的一些主要功能菜单. 一.功能区菜单 功能区菜单主要包括: 文件菜单: 主要用于新建文件,保存文件,另存为文件,打开文件,打 ...
- test11111111
test 博文内容中字符过多,拒绝显示 123123123
- 问题 C: 如沫春风 ---有毒的gets(),新OJ不能用!用scanf(%s)读入即可!——ZZNU新OJ
问题 C: 如沫春风 时间限制: Sec 内存限制: MB 提交: 解决: [提交] [状态] [讨论版] [命题人:admin] 题目描述 月亮很亮,亮也没用,没用也亮. 我喜欢你,喜欢也没用,没用 ...
- python基础认识
Python基础 一. 简介 Python是著名的“龟叔”Guido van Rossum在1989年圣诞节期间,为了打发无聊的圣诞节而编写的一个编程语言.豆瓣,Google.Yahoo等,甚至 ...
- 聊聊我理解的ANSI C、ISO C、GNU C、POSIX C
几句话了解C标准之间的关系 C语言标准 早期的计算机汇编语言是与机器平台紧密耦合的,为了屏蔽这种耦合,增加代码的可移植性,C语言随机出现. 二十世纪八十年代,为了避免各开发厂商用的C语言语法产生差异, ...