动手动脑1.当JAVA里定义的函数中去掉static后,怎么办?(如下程序,将square()函数的static去掉)

public class SquareIntTest {

    public static void main(String[] args) {
int result; for (int x = 1; x <= 10; x++) {
result = square(x);
// Math库中也提供了求平方数的方法
//result=(int)Math.pow(x,2);
System.out.println("The square of " + x + " is " + result + "\n");
}
} // 自定义求平方数的静态方法
//问:如果不加static,怎么办?
public static int square(int y) {
return y * y;
}
}

因为static 是静态的意思,main是静态的,想加载的时候就加载了,可将函数写在一个新的类中即可,如下所示:

public class SquareIntTest {

    public static void main(String[] args) {
int result; for (int x = 1; x <= 10; x++) {
result = new Test().square1(x);//非静态
System.out.println("The square of " + x + " is " + result + "\n");
}
}
}
class Test{
public int square1(int y) {
return y*y; }
}

动手动脑2.编写一个方法,使用纯随机数发生器生成指定数目(比如1000个)的随机整数。

(纯随机数发生器)

程序如下:

//博客园作业-编写一个方法,使用纯随机数产生器生成指定数目(比如1000个)的随机整数。
//李慧,2016.10.15 package boke; import java.util.Scanner; public class SuiJiShu { public static void main(String[] args) {
// TODO Auto-generated method stub
System.out.println("(此系统用于产生制定数目n的随机整数)");
System.out.printf("请输入n:");
Scanner scanner = new Scanner(System.in);
int n = scanner.nextInt(); //纯随机数发生器
int f1=1;
for(int i = 1;i <= n; i++){
f1=((7^5)*f1+0)% (2^10000);
//输出结果
System.out.print(f1+" ");
if(i%10==0)
System.out.println();
}
}
}

其运行结果:

动手动脑3.请看以下代码,你发现了有什么特殊之处吗?

// MethodOverload.java
// Using overloaded methods
//计算平方 public class MethodOverload { public static void main(String[] args) {
System.out.println("The square of integer 7 is " + square(7));
System.out.println("\nThe square of double 7.5 is " + square(7.5));
} public static int square(int x) {
return x * x;
} public static double square(double y) {
return y * y;
}

此程序中出现了两个函数名相同的函数,经运行系统没有报错,答案也是正确的。这是因为,当具备①方法名相同;②参数类型不同,参数个数不同,或者是参数类型的顺序不同,这两个条件的时候,同名函数才是正确的。但是,方法的返回值并不作为方法重载的判断条件。

练习:查看一下JDK中System.out.println()方法,你发现了什么?

System是jdk自带的一个类,他有很多的方法,这些方法都是静态的,也就是static的。System.out.print()就相当于一个函数,它之所以可以不断的重复使用,是因为它可以有不同类型的参数,不同个数的参数,参数的顺序也可以不同。

课后作业1:使用计算机计算组合数

(1)使用组合数公式利用n!来计算

程序如下:

package boke;

import java.math.BigInteger;
import java.util.Scanner; public class ZuHeShu { public static void main(String[] args) {
// TODO Auto-generated method stub
System.out.println("........求组合数C(n,k).........n为下标........");
System.out.print("请输入n,k:");
Scanner scan = new Scanner(System.in);
int n = scan.nextInt();
int k = scan.nextInt();
if(n<k)
    System.out.print("ERROR!");
   else
//n!=calculateN2(n);
System.out.print("C("+n+","+k+")="+cN(n)/cN(k)/cN(n-k));
}
public static long cN(int n) {
if(n==1 || n==0){
return 1;
} return n*cN(n-1);
}
}

运行结果是:

(2)使用递推的方法用杨辉三角形计算

package boke;

import java.util.Scanner;

public class ZuHeShu2 {

    public static void main(String[] args) {
// TODO Auto-generated method stub
System.out.println("(杨辉三角做法)........求组合数C(n,k).........n为下标........");
System.out.print("请输入n,k:");
Scanner scan = new Scanner(System.in);
int n = scan.nextInt();
int k = scan.nextInt();
if(n<k)
System.out.print("ERROR!");
else{
//n!=calculateN2(n);
//size = new Long(s);
// long A = new Long(CN2(n+1,k)-CN2(n,k-1));
System.out.print("C("+n+","+k+")=");
System.out.println(CN2(n+1,k)-CN2(n,k-1));}
}
public static long cN(int n) {
if(n==1 || n==0){
return 1;
}
return n*cN(n-1);
} //杨辉三角的方法递推计算
public static long CN2(int n,int k){
long A = cN(n)/cN(k)/cN(n-k);
return A; } }

其运行结果:

 (3)使用递归的方法,用组合数递推公式计算

package boke;

import java.util.Scanner;

public class ZuHeShu3 {

    public static void main(String[] args) {
// TODO Auto-generated method stub
System.out.println("(递归的方法利用公式)........求组合数C(n,k).........n为下标........");
System.out.print("请输入n,k:");
Scanner scan = new Scanner(System.in);
int n = scan.nextInt();
int k = scan.nextInt();
if(n<k || k<1)
System.out.print("ERROR!");
else{
//n!=calculateN2(n);
System.out.print("C("+n+","+k+")=");
System.out.println(CN3(n,k));}
}
public static long cN(int n) {
if(n==1 || n==0){
return 1;
}
return n*cN(n-1);
} //递归计算
public static long CN2(int n,int k){
if(n==1 || n==0){
return 1;}
return cN(n)/cN(k)/cN(n-k);
} public static long CN3(int n,int k){
if(n == 1 || n == 0)
{return 1;}
return (CN2(n+1,k)-CN2(n,k-1));
}
}

其运行的结果:

       

其如果出现ERROR时,和上述两个例子是属于相同的情况。

 课后作业2:递归编程解决汉诺塔问题(用JAVA实现)

//disk是磁盘...sourcePeg源PEG...destinationPeg目标PEG...tempPeg临时PEG

package work;

public class Hanoi
{
// 递归移动塔之间的磁盘
public static void solveTowers( int disks, int sourcePeg,
int destinationPeg, int tempPeg )
{
// 移动的时候
if ( disks == 1 )
{
System.out.printf( "\n%d ——> %d", sourcePeg, destinationPeg );
return;
} // 递归步骤--移动(磁盘1)磁盘sourcepeg
// to tempPeg using destinationPeg
solveTowers( disks - 1, sourcePeg, tempPeg, destinationPeg ); // 最后从sourcepeg到destinationpeg移动磁盘
System.out.printf( "\n%d ——> %d", sourcePeg, destinationPeg ); // 移动(磁盘1)从临时peg到目的peg磁盘
solveTowers( disks - 1, tempPeg, destinationPeg, sourcePeg );
} public static void main( String[] args )
{
int startPeg = 1; // 值1表示startpeg输出
int endPeg = 3; // 值3表示endpeg输出
int tempPeg = 2; // 值2表示temppeg输出
int totalDisks = 3; //有几个托盘 //移动所有磁盘。
solveTowers( totalDisks, startPeg, endPeg, tempPeg );
}
}

其结果截图:

课后作业3:使用递归方式判断某个字串是否是回文( palindrome )

package boke;

import java.util.Scanner;

public class HuiWeiShu {
public static void main(String[] args) {
String S = " ";
System.out.println("(此程序用于判断某个字符串s是否是回文)");
System.out.println("请输入字符串S:");
Scanner scan = new Scanner(System.in);
S = scan.next();
//输出结果
System.out.println(ishui(S));
}
public static boolean ishui(String S){
int L = S.length();//字符串的长度
if(L<=1){
return true;}//字符串是回文
else if(S.charAt(0)!=S.charAt(L-1)){
return false;
}
return ishui(S.substring(1,L-1));
}}

其运行结果:

经运行,其结果正确。

JAVA方法03之动手动脑问题解决的更多相关文章

  1. java异常处理动手动脑问题解决和课后总结

    动手动脑 一.问题:请阅读并运行AboutException.java示例,然后通过后面的几页PPT了解Java中实现异常处理的基础知识. 1.源代码 import javax.swing.*; cl ...

  2. java课堂第一次随机测试和课件课后动手动脑问题解决(2019-9-16 )

    一.课堂测试 1.课堂测试:花二十分钟写一个能自动生成30道小学四则运算题目的 “软件” 要求 (1)减法结果不能为负数 (2)乘法结果不得超过一百,除法结果必须为整数 (3)题目避免重复: (4)可 ...

  3. JAVA06数组之动手动脑问题解决

     一.随机生成10个数,填充一个数组,然后用消息框显示数组内容,接着计算数组元素的和,将结果也显示在消息框中. 1.设计思路:首先生成10个随机数,然后存放至长度至少是10的数组中,然后计算10个随机 ...

  4. Java类和对象动手动脑

    动手动脑1 以下代码为何无法通过编译?哪儿出错了?

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

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

  6. JAV07接口与继承之动手动脑问题解决

    动手动脑:请自行编写代码测试以下特性:在子类中,若要调用父类中被覆盖的方法,可以使用super关键字. 1.源代码: package Work; class A{ public A(){ System ...

  7. Java文件与类动手动脑

    动手动脑1: 使用Files. walkFileTree()找出指定文件夹下所有大于指定大小(比如1M)的文件. package classJava; import java.io.IOExcepti ...

  8. Java课程作业之动手动脑(四)

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

  9. Java第一节课动手动脑

    在第一节课的动手动脑中,主要解决四则运算问题. 首先第一个是出30道四则运算题目,在100以内.这个问题需要控制随机数生成的范围和结果的范围在100以内就可以. 第一次改进是3点:一为避免重复,二为定 ...

随机推荐

  1. Dynamics AX 2012 R2 通过数据源保存记录时触发的方法

    我们都知道,在窗体上保存记录时,会像在表上保存时一样,触发很多方法.这里Reinhard找到了一个流程图,看看都触发了哪些方法,并且这些方法是以怎样的顺序被触发的. 窗体上数据源的Validate() ...

  2. LIBCD.lib(wincrt0.obj) : error LNK2001: unresolved external symbol _WinMain@16 Debug/firstapi.exe :

    #include <windows.h> #include <iostream.h> void main() { char SourceFileName[MAX_PATH]; ...

  3. Tomcat启动,不能加载项目问题。

    项目部署时遇到的一个Tomcat问题:     启动tomcat后,不能加载项目 直接启动完成 但是项目未加载 最后找到原因:  把环境变量Catalina_HOME删除掉,就能加载. tomcat启 ...

  4. 【转】Hibernate 常见异常

    转载地址:http://smartan.iteye.com/blog/1542137 Hibernate 常见异常net.sf.hibernate.MappingException        当出 ...

  5. springmvc json字符串转化成json对象

    问题出现在 :页面数据列表的展示出现 [object HTMLInputElement] 找到问题的所在原因后又三种解决方案 一:格式化json字符串为json对象字符串 success:functi ...

  6. input标签file的value属性IE兼容性问题

    在IE中input标签file的value属性是只读的,不能通过js来改变,如下代码在IE中就是无效的: var input = document.getElementById('file'); in ...

  7. https 单向认证和双向认证配置

    HTTPS 是我们开发中经常用到的通信加密技术,能有效保护我们网络访问中的安全,本文主要讲解单向 和 双向 https 的配置.关于https 的实现原理在这里我就不赘述了,附上阮一峰老师的关于htt ...

  8. Excel通过身份证获取出生年月,性别,年龄,生肖,星座,省份等信息总结归纳

    Excel通过身份证获取出生年月,性别,年龄,生肖,星座,省份等信息总结归纳 早期的身份证号码为15位数字,现在使用的身份证号码为18位数字,它们的含义如下:(1)15位:1-6位为地区代码,7-8位 ...

  9. UI进阶 跳转系统设置相关界面的方法

    跳转系统设置界面,例如提示用户打开定位.蓝牙或者WIFI,提醒用户打开推送或者位置权限等 在iOS6之后,第三方应用需要跳转系统设置界面,需要在URL type中添加一个prefs值,如下图: 跳转系 ...

  10. 需求:输入一个年份和月份 ,显示当前月日情况 ,星期数要对应准确 * 1.1900年1月1号开始 * 2.星期 : 直接用总天数对7求余数 31 28 59 / 7 = 5 * 3.以\t来个开

    public class Demo4 { /** * @param args */ public static void main(String[] args) { // TODO Auto-gene ...