java小程序(课堂作业02)
1,三种方法计算组合数
①设计思路:第一种方法就是通过阶乘公式然后运用公式计算出组合数,第二种通过公式推导出cnk=n/(n-k)cnk-1,然后然后从ckk
开始运算到cnk,第三种方法就是通过递归从cnk开始一直运行cnk=n/(n-k)cnk-1直到ckk。
②流程图
③源代码
//信1605-3程浩20163667
import java.util.*;
public class ZuHeShu {
public static void main(String []args)
{
Scanner sc=new Scanner(System.in);
System.out.println("请输入n的值:");
int n=sc.nextInt();
System.out.println("请输入k的值:");
int k=sc.nextInt();
while(n<k)
{
System.out.println("输入错误!请重新输入:");
System.out.println("请输入n的值:");
n=sc.nextInt();
System.out.println("请输入k的值:");
k=sc.nextInt();
}
System.out.println("选择一种计算方式:1,组合式公式2,递推3,递归:");
int j=sc.nextInt();
if(j==1)
{
gongshi1(n,k);
}
else if(j==2)
{
gongshi2(n,k);
}
else if(j==3)
{
gongshi3(n,k);
}
else
{
System.out.println("输入错误!");
}
}
public static void gongshi1(int n,int k)
{
long a=calculateN(n);
long b=calculateN(k);
long c=calculateN(n-k);
long sum=a/(b*c);
System.out.println("结果为:"+sum);
}
public static void gongshi2(int n,int k)
{
long cnn=1,ckk=1,cnk=1,sum=0;
for(int i=1;i<=n;i++)
{
cnn=cnn*i;
}
for(int i=1;i<=k;i++)
{
ckk=ckk*i;
}
for(int i=1;i<=n-k;i++)
{
cnk=cnk*i;
}
sum=cnn/(ckk*cnk);
System.out.println("结果为:"+sum);
}
public static void gongshi3(int n,int k)
{
long sum=calculateN1(n,k);
System.out.println("结果为:"+sum);
}
public static long calculateN(int n) {
if(n==1 || n==0){
return 1;
}
return n*calculateN(n-1);
}
public static long calculateN1(int n,int k) {
long sum=1;
if(n==k)
{
return sum;
}
return sum*n*calculateN1(n-1,k)/(n-k);
}
}
④结果截图
2,汉诺塔
①设计思路:首先将起始塔上的n-1个盘子移到中间塔上,借助目标塔;然后再将第n个移到目标塔上,中间塔上的n-1个盘子移到目标塔上,借助起始塔。移动借助一个方法,将方法写成递归函数,递归调用。
②流程图
③源代码
//用递归方式编程解决汉诺塔问题。
//信1605-3程浩20163667
import java.util.Scanner;
public class HanNuoTa
{
public static int bushu=1;
//递归的移动塔上的盘子
public static void solveTowers( int disks, int sourcePeg,
int destinationPeg, int tempPeg )
{
// base case -- only one disk to move
if ( disks == 1 )//只剩一个盘子就退出
{
System.out.printf( "\n第"+(bushu++)+"步:%d --> %d", sourcePeg, destinationPeg );
return;//return空,去掉后就会出错
}
//将disks-1个盘子借用目标塔从起始塔移动到中间塔
solveTowers( disks - 1, sourcePeg, tempPeg, destinationPeg );
//destinationPeg是最终的塔;sourcePeg表示起始塔, tempPeg表示中间塔
// 输出结果,从开始点->终点
System.out.printf( "\n第"+(bushu++)+"步:%d --> %d", sourcePeg, destinationPeg );
// 移动中间塔上的disks-1个到目标塔
solveTowers( disks - 1, tempPeg, destinationPeg, sourcePeg );
}
public static void main( String[] args )
{
int startPeg = 1; // 开始位置设为1
int endPeg = 3; //目标塔设为3
int tempPeg = 2; // 中间塔设为2
Scanner sc=new Scanner(System.in);
System.out.println("请输入盘子个数:");
int totalDisks=sc.nextInt();//盘子个数
// 调用递归方法
solveTowers( totalDisks, startPeg, endPeg, tempPeg );
} // end main
} // end class TowersOfHanoi
③结果截图
3,判断回文
①设计思路:先用一个窗口来接收输入的字符串,将这个字符串看成char型数组通过s.charAt(int i),判断第i个和倒数第i是否相等然后将结果输出。
②流程图
③源代码
//信1605-3程浩20163667
import javax.swing.JOptionPane;
public class HuiWen {
public static void main(String[] args)
{
String test=JOptionPane.showInputDialog( "请输入需要判断的字符串:" );
int i=0;
int j=test.length()-1;
String jieguo=" ";
if(panduan(test,i,j))
{
jieguo=test+"判断是否回文的结果为:是。";
}
else
{
jieguo=test+"判断是否回文的结果为:否。";
}
JOptionPane.showMessageDialog(null, jieguo,"结果",JOptionPane.INFORMATION_MESSAGE );
}
public static boolean panduan(String test,int i,int j)
{
if(i>j)
{
throw new IllegalArgumentException();
}
else if(i==j)
{
return true;
}
else if(i==j-1)
{
return test.charAt(i)==test.charAt(j);
}
else
{
return ((test.charAt(i)==test.charAt(j))&&panduan(test,i+1,j-1));
}
}
}
④结果截图
java小程序(课堂作业02)的更多相关文章
- 输出多行字符的一个简单JAVA小程序
public class JAVA { public static void main(String[] args) { System.out.println("-------------- ...
- 浏览器兼容java小程序配置说明
最近在使用的一个web应用系统是内嵌了java小程序,遇到了各种浏览器兼容性问题,现梳理如下: 1.通过以下链接检测当前电脑是否已经安装有java https://java.com/zh_CN/dow ...
- 框架一般用作Java应用程序的窗口,而Applet是Java小程序的窗口
框架一般用作Java应用程序的窗口,而Applet是Java小程序的窗口. 与Frame不同,Applet是在网页中显示的,也可以通过添加Panel进行组件布局. package TomAwt; im ...
- 【小程序分享篇 一 】开发了个JAVA小程序, 用于清除内存卡或者U盘里的垃圾文件非常有用
有一种场景, 手机内存卡空间被用光了,但又不知道哪个文件占用了太大,一个个文件夹去找又太麻烦,所以我开发了个小程序把手机所有文件(包括路径下所有层次子文件夹下的文件)进行一个排序,这样你就可以找出哪个 ...
- 2015.11.27初识java一集简单的java小程序
JAVA配置环境变量方法: 1.打开我的电脑--属性--高级--环境变量 2.新建系统变量JAVA_HOME 和CLASSPATH 变量名:JAVA_HOME变量值:D:\Java\jdk1.7.0_ ...
- java的数据类型,几个java小程序
1:求圆的面积 还好看了c++,不然直接看这课件还真是看不懂……加油吧 要从键盘读入数据可以用Scanner类的nextlnt()或者nextDouble()方法,首先创建Scanner类的一个实例, ...
- java 小程序开发PKCS7Padding 解密方法实现,以及错误Cannot find any provider supporting AES/CBC/PKCS7Padding 解决办法
近日在对接小程序API,其中wx.getUserInfo api返回的数据encryptedData 的解密算法要求为: AES-128-CBC,数据采用PKCS#7填充. 经过一番查询,得到java ...
- 首次编译Java小程序
public class helloworld { public static void main(string[] args) { system.out.println("hello wo ...
- java 小程序查看器 启动:未初始化小程序 解决方法
欢迎大家转载.为保留作者成果,转载请注明出处,http://blog.csdn.net/netluoriver,有些文件在资源中也能够下载.假设你没有积分.能够联系我索要! 在执行java程序的时候突 ...
- JAVA 小程序之ATM
一个JAVA的小程序,主要要求有模块化编程的思想,能够把ATM中各个功能独立成为一个一个的方法. ATM主要功能有: 查询余额: 取款: 存款: 修改密码: 退出. 以上功能均由独立的方法给出,具体实 ...
随机推荐
- ss-libev控制脚本
适用于:shadowsocks-libev-3.0.3 操作系统:CentOS6.8 #!/bin/sh SHADOWSOCKS_SERVER="/usr/local/shadowsocks ...
- 20165228 2017-2018-2 《Java程序设计》第8周学习总结
20165228 2017-2018-2 <Java程序设计>第8周学习总结 教材学习内容总结 进程与线程的关系 多线程的运行机制 线程的四种状态:新建.运行.中断.死亡 使用Thread ...
- Quorum算法
分布式系统中,一般保存多个数据副本,明显可以提高系统可靠性.并且存储这些数据副本的节点,不仅做容灾用,也可以提供服务,作负载均衡. 这里就涉及到一个数据一致性的问题,也就是各副本间要进行同步,来保持最 ...
- PHPweb应用攻击总结(转)
XSS跨站脚本 概念:恶意攻击者往Web页面里插入恶意html代码,当用户浏览该页之时,嵌入其中Web里面的html代码会被执行,从而达到恶意用户的特殊目的. 危害: 盗取用户COOKIE信息. 跳转 ...
- 【leeetcode】125-Valid Palindrome
problem 125. Valid Palindrome 参考 1. Leetcode_Valid Palindrome; 完
- Python用re正则化模块在字符串查找特定字符串
实验需要,在一个含有几亿个字符的txt文件中查找特定的字符串,首先用re模块进行查找 from time import clock import re start=clock() label_file ...
- CCF-棋局评估 201803-04(版本 2.0)------(之前写了一个臃肿的1.0版 ,还沾沾自喜 233)
核心 : 博弈搜索树 双方得分互为相反数 dfs (x,y,player): 玩家player下完(x,y)之后的得分最大值 易错: 先判断输赢,再判断平局 待改进: check() 函数写的 ...
- tomcat配置https–采用JDK自带的keytool工具生成证书
转自:http://blog.csdn.net/huangxinyu_it/article/details/41693633 有关http与https的区别请看<浅谈http与https的区别( ...
- 《DSP using MATLAB》Problem 6.21
代码: %% ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ %% Output In ...
- Java线程池 详解(图解)
来源:www.jianshu.com/p/098819be088c 拓展: 手动创建 new ThreadPoolExecutor 的使用: https://segmentfault.com/a/11 ...