java 作业03方法

思考问题1

 

编写一个方法,使用以上算法生成指定数目(比如1000个)的随机整数。

一 思路

 

   1 定义主方法。

   2 定义数组存放随机数。

   3 确定种子。

   4 用随机数公式生成随机数。

   5 输出随机数。

 

二 程序流程图

 

三 源代码

 

   public class random1000 {

   

    public static void main(String[] args){   //主函数

        int[] a=new int[7];                     //定义数组存放随机数

        //Random ran= new Random( System.currentTimeMillis() );

        a[0]=2;                                  //种子

       

        System.out.println("生成的五个随机数是:");

        for(int i=1;i<=5;i++){

           

            a[i]=(7*a[i-1]+7)%1000;      //用随机数公式生成随机数

            System.out.println(a[i]);    //输出

        }

 

    }

 

}

四 程序结果截图

 

                                                                                                                   

 

思考问题2

JDK中System.out.println()方法

Print方法有很多重载的方法。当不传值时会调用println()空参数方法,这个方法里面做了换行操作,这个方法它是有打印数据的,只不过这个是一个换行符。

 

思考问题3

请看以下代码,你发现什么特殊之处了吗?

 

 

square()方法中方法名一样,参数类型不一样。

函数重载体现在(1)方法名相同;(2)参数的个数不同,参数类型不同,参数类型的顺序不同。

 

程序题

一 计算组合数

使用计算机计算组合数有三种方法:

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

     

 

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

 

 

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

1 用递归的方法用组合数递推公式计算

思路

1)定义主方法

2)输入组合数。

3)调用方法求组合数

4)定义求组合数的方法。

5)方法结束的条件。

6)用杨辉三角递归调用自己。

7)输出结果

流程图                                                                                         

 

 

 

 

源代码

import java.util.Scanner;                    

 

public class yanghui3 {

    public static void main(String args[]){    //定义主方法

       

        System.out.println("please input a zuheshu"); //输入组合数

        Scanner in=new Scanner(System.in);

        int n=in.nextInt();

        int k=in.nextInt();

       

if (n < k || n <= 0 || k <= 0) {

            System.out.println("n,k数据输入不合理");

            return;

           }

        System.out.println(digui(n,k));                //调用方法求组合数

    }

 

    public static int digui(int n,int k)           //定义求组合数方法

    {

       

        if(k==0||k==n)                            //方法结束条件

            return 1;

        else

            return digui(n-1,k)+digui(n-1,k-1);  //杨辉三角计算组合数递归调用

    }

}

 

 

程序结果截图

  

2 用组合数公式计算

思路

1)定义主方法

2)输入组合数。

3)调用方法求组合数

4)定义求组合数的方法。

5)方法结束的条件。

6)用杨辉三角递归调用自己。

7)输出结果

流程图                                                                                         

             

 

 

 

源代码

import java.io.*;

public class yanghui {

    public static void main(String args[]) throws IOException //定义主方法

    {

        int n,k,a;

       

        System.out.println("Please input n,k:");        //输入

    BufferedReader read=new BufferedReader(new InputStreamReader(System.in));                        //读入字符串

        String aa=read.readLine();

        String bb=read.readLine();

       

        n=Integer.parseInt(aa);                        //类型转换为整型

        k=Integer.parseInt(bb);

 

 if (n < k || n <= 0 || k <= 0) {

            System.out.println("n,k数据输入不合理");

            return;

           }

 

        

        a=jiecheng(n)/(jiecheng(k)*jiecheng(n-k));

       

        System.out.println("组合数的值是:"+a);     //输出

    }

 

    public static int jiecheng(int n){             //定义求阶乘的方法

        if(n==1||n==0)

            return 1;

        else

            return n*jiecheng(n-1);                 //递归调用

    }

}

 

程序截图

  

 

 

二 汉诺塔题

递归编程汉诺塔问题,用程序实现

 

1 思路

1)        定义主方法

2)        输入盘子个数

3)        调用玩游戏的方法

4)        定义移动一个盘子的方法

5)        定义玩游戏的方法

2流程图

   

 

3源代码

 

import java.util.Scanner;

public class hannuota {

    static int i=0;

    public static void main(String[] args) {        //定义主方法

        // TODO Auto-generated method stub

 

        int n;

       

        System.out.println("Please input n:");  //输入盘子个数

        Scanner in=new Scanner(System.in);

        n=in.nextInt();

        han(n,'a','b','c');               //调用玩游戏的方法

    }

   

    public static void move(char a,int n,char c){     //定义移动一个盘子的方法

        i++;

      System.out.println("第"+i+"步,"+"将第"+n+"个盘子从"+a+"移到"+c);

     

       

    }

   

   public static void han(int n,char a,char b,char c){ //定义玩游戏的方法

   

       if(n==1)                   //盘子是一个的时候把第一个盘子从a移到c;

           move(a,1,c);  

       else

       {

           han(n-1,a,c,b);    //将a上1-n-1的移到b,c过渡

           move(a,n,c);       //将编号为n的从a移到c

           han(n-1,b,a,c);    //将b上1-n-1的移到a,c过渡

 

       }

    }

 

}

 

4 程序截图

 

 

 

三 回文数

1 思路

6)        定义主方法

7)        输入字符串

8)        调用玩游戏的方法

9)        定义移动一个盘子的方法

10)    定义玩游戏的方法

2流程图

 

     

 

3 源代码

import java.util.Scanner;

public class huiwenshu {

 

    public static void main(String[] args) {              //定义主方法

        // TODO Auto-generated method stub

 

        String str="";

        System.out.println("Please input a string:");   //输入字符串

       

        Scanner in=new Scanner(System.in);

       

        str=in.nextLine();

        int len=str.length();                            //求字符串长度

        System.out.println("true is palindrome,false is not:"+pan(str,len-1,0,len)); }

public static boolean pan(String str,int h,int z,int len){ //定义判断是否是回文数的方法

   

 

    if(len==0||len==1)       //函数结束条件

        return true;

   

    if(str.charAt(h)!=str.charAt(z))  //对应的不相等就不是回文数

            return false;

    return  pan(str,h-1,z+1,len-2);  //递归调用

   

}

 

}

4 程序结果截图

 

 

posted on 2016-10-15 20:20  王甜甜的小摩托  阅读(150)  评论(0编辑  收藏  举报

导航