浙大 Java语言程序设计编程答案7 下载本文

内容发布更新时间 : 2025/1/6 16:51:00星期一 下面是文章的全部内容请认真阅读。

实验8 Method的使用

程序填空,不要改变与输入输出有关的语句。

1. 求1 + 1/2! +....+ 1/n!

输入一个正整数repeat (0

要求定义并调用函数fact(n)计算n的阶乘。

例:括号内是说明 输入:

2 (repeat=2) 2 (n=2) 10 (n=10) 输出: 1.5 1.7183

public class Test50001 { public static void main(String[] args) { int ri,repeat; int i,n; double s; Scanner in=new Scanner(System.in); repeat=in.nextInt(); for(ri=1;ri<=repeat;ri++){ n=in.nextInt(); /*-----------*/

s=0;

for(i=1;i<=n;i++) s+=1.0/fact(i);

System.out.println((long)(s*10000+0.5)/10000.); } } /*---------------*/

static double fact(int n) { int i;

double f=1;

for(i=1;i<=n;i++) f*=i; return f; }

}

/* 方法fact(n)也可以用以下递归算法设计 static double fact(int n) { if(n==1)

return 1; else

return n*fact(n-1); } */

2. 求a+aa+aaa+aa…a

输入一个正整数repeat (0

要求定义并调用函数fn(a,n),它的功能是返回aa…a(n个a)。例如,fn(3,2)的返回值是33。

例:括号内是说明 输入

2 (repeat=2) 2 3 (a=2, n=3) 8 5 (a=8, n=5) 输出

246 (2+22+222)

98760 (8+88+888+8888+88888)

import java.util.Scanner; public class Test50002{

public static void main(String args[]){ int ri, repeat; int i, n,a; long sn; Scanner in=new Scanner(System.in); repeat=in.nextInt(); for(ri=1; ri<=repeat; ri++){ a=in.nextInt(); n=in.nextInt(); /*------------*/

sn=0;

for(i=1;i<=n;i++) sn+=fn(a,i);

System.out.println(sn); } }

/*------------*/

static int fn(int a,int n){ int s=0;

for(int i=1;i<=n;i++) s=s*10+a; return s; }

}

/* 方法fn()也可以用以下递归算法设计 static int fn(int a,int n){ if (n==1) return a; else

return fn(a,n-1)*10+a; } */

3. 统计一个整数中数字的个数

输入一个正整数repeat (0

要求定义并调用函数countdigit(number,digit),它的功能是统计整数number中数字digit的个数。例如,countdigit(10090,0)的返回值是3。

例:括号内是说明 输入:

3 (repeat=3) -21902 2

345543 输出:

count=2 (-21902中有2个2) count=1 (有1个2)

count=0 (345543中没有2)

import java.util.Scanner; public class Test50003{

public static void main(String args[]){ int ri, repeat; int count; long n; Scanner in=new Scanner(System.in); repeat=in.nextInt(); for(ri=1; ri<=repeat; ri++){ n=in.nextInt();