03-方法ppt动手动脑问题及课后实验性问题总结

一.如何不使用static来进行调用函数?

       1.自己定义的不需要都是static,但是要在主函数中调用就需要static了,因为main是静态 的,在类加载时就加载了。如果想用又不加可以吧自己写的方法写在一个类中调用就行。主函数一般也只是调用不做数据处理。

       2.static方法是在编译的时候确定的,在类装入内存的时候也同时装入内存了。而非static方法是在类的实例化的时候装入内存的,其必须依赖于类的实例。

实例在装入堆栈的时候是会附加上指向method area的指针,所以可以在非静态方法中调用static方法。

       3.static方法中可以通过创建(new)该类的引用或者在调用static方法的时候传递一个对象的引用过去,这种方法来调用非static方法。

          典型的例子就是static void main()方法,在这个static方法中可以看到,会创建任意的实例,然后通过这些实例来调用所属类的非静态方法。

特别注意的是:由JVM的执行机制决定了在static方法中是不能直接调用该类的其它非static方法的。

         因为类方法(static方法)执行的时候,其所在的堆栈中是没有指向对象的引用的任何信息的,而非static方法在调用的时候又必须要知道调用该方法的对象的引用。所以从这里可以看出,static方法中是没有办法直接调用非static方法的。

  从另外一方面来讲,static方法中是不存在this的,而this是一个很重要的指向对象的引用的关键字(每个非static方法中都应该存在的,并且指向了调用该方法的对象的引用;非static方法调用改类其他方法的时候实际上是用到了this.[Method])。所以没有this的static方法是不可能直接调用该类中的非static方法的。

二.动手动脑:编写一个方法,使用 x[n+1]=(a*x[n]+c) mod m生成指定数目(比如1000个)的随机整数

       在java中,我们可以通过两种方式来获取随机数(generating a random number)一种是大家熟悉的java.lang.Math.Random()静态方法,另一种是创建java.util.Random对象。下面是两种方法的使用过程:

       1)java.lang.Math.random()

在使用这一静态方法的时候,我们不需要import任何包,因为java.lang.*包是默认载入的,下面举例说面使用方法:

public class RandomTest{
    public static void main(String[] args){
        int i=Math.random();//random()会自动产生一个0.0-1.0的双精度随机数
        System.out.println(i);//输出
        i=Math.random()*1000;//产生0-1000的双精度随机数  
        System.out.println(i);
        int b=(int)(Math.random()*1000);//产生0-1000的整数随机数  
        System.out.println(b);
    }
}

       2)创建java.util.Random对象

import java.util.random
public class RandomTest{
    public static void main(String[] args){
        Random random=new Random();//创建random对象
        int intNumber=random.nextInt();//获取一个整型数
        float floatNumber=random.nextFloat();//获取一个浮点数(0-1)
        double doubleNumber=random.nextDouble();//获取双精度数(0-1)
        boolean booleanNumber=random.nextBoolean();//获取boolean数
        System.out.println("intNumber:"+intNumber);
        System.out.println("floatNumber:"+floatNumber);
        System.out.println("doubleNumber:"+doubleNumber);
        System.out.println("booleanNumber:"+booleanNumber);
    }
}

       random在产生随机数的时候使用当前的时间作为基数,我们可以通过System.currentTimeMillis()来获取这个基数。当然我们也可以指定基数:

Random random=new Random(100),不过,同一基数所产生的随机数序列是一样的。

实现1000个随机数字的方法:

public class RandomTest{
    public static void main(String[] args){
        int z;
        for(int n=0;n<1000;n++)
        {
            int x0=(int)(Math.random()*1000);
            int a=(int)(Math.random()*1000);
            int c=(int)(Math.random()*1000);
            int m=(int)(Math.random()*1000);//产生0-1000的整数随机数  
            int y=n+1;
            z=(a*x0+c)%m;
            System.out.println(y+":"+z);
        }
    }
}

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

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

 四.利用计算机计算组合数:

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

import java.math.BigInteger;
import java.util.Scanner;

public class YangHui {

    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.println("ERROR!");
else if(n==0&&k==0)
System.out.println("1");
else System.out.print("C("+n+","+k+")="+Calculate(n)/Calculate(k)/Calculate(n-k)); } public static long Calculate(int n) { if(n==1) { return 1; } return n*Calculate(n-1); } }

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

import java.util.Scanner;

public class YangHui1 {

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        System.out.println("求组合数C(n,k):(n为下标)请输入n,k:");
        Scanner scan = new Scanner(System.in);
        int n = scan.nextInt();
        int k = scan.nextInt();
        System.out.print("计算结果为:"+Calculate(n,k));
    }
    public static long factorial(int a)
    {
         if(a==0||a==1) return 1;
         return a*factorial(a-1);
    }
    public static long Calculate(int n,int k)
    {
            return factorial(n)/(factorial(k)*factorial(n-k));
    }
}

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

      

import java.util.Scanner;
public class YangHui2 {

    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();
        System.out.print("计算结果为:"+Cal(n,k));
    }
    public static long Cal(int N , int k)  
    {     
        if(0 == k || 0 == N)  
        {  
            return 1;  
        }  
          
        if(N < k)  
        {  
            return 0;  
        }  
          
        if(N == k)  
        {  
            return 1;  
        }  
          
        return Cal(N-1,k) + Cal(N-1,k-1);  
    }  
}

四.使用递归方式判断字符串是否是回文数

import java.util.Scanner;

public class HuiWen {
    public static void main(String[] args) {
        String S=" ";
        System.out.println("请输入字符串S:");
        Scanner sc= new Scanner(System.in);
        S=sc.next();
        Judge(S);
    }
    public static void Judge(String S)
    {
        int a= S.length();//字符串的长度
        int b=0;
        if(a==1)
        {
            System.out.println("单个字符是回文字符串!");
        }
        else if(S.charAt(0)!=S.charAt(a-1))//判断确定位置的字符是否一样
        {
            System.out.println("此字符串不是回文的!");
            b=1;
        }
        else
        {
            System.out.println("此字符串是回文的!");
            b=1;
        }
        if(a-2>0&&(b!=1))
            Judge(S.substring(1,a-1));//截取从1到a-1的字符串重新存入字符串S的存储内存
    }
}

 

posted @ 2016-10-16 00:59  蘑菇蘑菇终于开花了  阅读(159)  评论(0编辑  收藏  举报